1

当我们有一个对象具有基于其他属性生成的属性时,通常我们实现+keyPathsForValuesAffecting{PropertyName}类方法。

对于我的 NSManagedObject 上的属性,我要做的基本上是相同的事情,但要遍历关系。

我的模型很简单;我有两个实体,应用程序和版本(我正在创建一个生成 appcast 的应用程序)。当 App 的属性发生变化时,因为我实现了上面的方法,所以 -appcast 字符串发生了变化,并且所有的绑定都被适当地更新了。

但是,当任何特定应用程序版本(对多关系)的任何属性发生更改时,-appcast 属性不会正确生成。我可以修复/解决方法吗?

4

1 回答 1

3

这是一个迟到的答案,但我认为这是一种常见的情况,而且答案肯定不是显而易见的。

我通常会观察 managedObjectContext 的变化,然后检查是否有任何已更改的对象是我想要注意的对象。所以,在你的NSManagedObject子类中:

// We need to register for the notification in both awakeFromFetch
// AND awakeFromInsert, since either one could be called, depending on
// if the object was previously-created or not
- (void)awakeFromFetch {
    [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(managedObjectContextDidChange:) name: NSManagedObjectContextObjectsDidChangeNotification object:[self managedObjectContext]];
}

- (void)awakeFromInsert {
    [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(managedObjectContextDidChange:) name: NSManagedObjectContextObjectsDidChangeNotification object:[self managedObjectContext]];
}

- (void)managedObjectContextDidChange:(NSNotification *)notification {
    // Get a set containing ALL objects which have been changed
    NSSet *insertedObjects = [[notification userInfo] objectForKey:NSInsertedObjectsKey];
    NSSet *updatedObjects = [[notification userInfo] objectForKey:NSUpdatedObjectsKey];
    NSSet *deletedObjects = [[notification userInfo] objectForKey:NSDeletedObjectsKey];

    NSSet *changedObjects = [insertedObjects setByAddingObjectsFromSet:updatedObjects];
    changedObjects = [changedObjects setByAddingObjectsFromSet:deletedObjects];

    if ([changedObjects intersectsSet:[self versions]]) {
        [self willChangeValueForKey:@"appCast"];
        [self didChangeValueForKey:@"appCast"];
    }
}

从性能的角度来看,这当然不是理想的,因为每次对象图中的任何内容发生更改时都会触发此通知,但我发现它是实现此目的最直接的方法。

于 2009-09-01T00:19:47.270 回答