9

有两个实体:作者和书籍。Author 具有属性 authorName 和一对多关系书籍。书有几个属性和一个关系作者。有一个视图控制器(VCAuthor)来编辑作者对象。子视图控制器(VCBook)用于编辑作者的书籍。只有一个托管对象上下文。在 VCBook 类中,我将 undomanager 分组如下

-(void)viewDidLoad
{    
    NSUndoManager *anUndoManager = [[NSUndoManager  alloc] init];
    [self.book.managedObjectContext setUndoManager:anUndoManager];
    [anUndoManager release];
    [self.book.managedObjectContext.undoManager beginUndoGrouping];
}

-(void)cancelAction:(id)sender
{
    NSLog(@"%@", self.author.authorName);
    [self.book.managedObjectContext.undoManager endUndoGrouping];
    [self.book.managedObjectContext.undoManager undoNestedGroup];
    self.book.managedObjectContext.undoManager = nil;
    NSLog(@"%@", self.author.authorName);    
    [self dismissModalViewControllerAnimated:YES];  
}

cancelAction 链接到 VCBook 上的取消按钮,该按钮用于撤消在 VCBook 中所做的所有更改。

问题就在这里:首先,在 VCAuthor 中,我在 UITextfiled authorNameTextField 中编辑从 Obama 到 Big Obama 的 authorName,并通过 - (void)viewWillDisappear:(BOOL)animated 中的 author.authorName = authorNameTextField.text 将其保存到 MOC {} 方法。然后我进入子视图控制器 VCBook 编辑作者的书籍,然后单击取消按钮返回 VCAuthor。我发现 authorName 仍然是 Obama,这意味着 authorName 的预期更改已被撤消。authorName 的变化根本不在 undo 组中,为什么会发生这种情况呢?附言。当然,当我回到 VCAuthor 时,我会重新加载数据。我只是在撤消之前和之后 NSLog authorName。撤消前authorName为改过的大奥巴马,撤消后为奥巴马

4

1 回答 1

9

有几件事要考虑。首先,在这种情况下,我会使用单独的 MOC 而不是撤消管理器。也就是说,我会做这样的事情(假设ARC - 如果需要,你可以做映射)......

您必须有一些其他代码通过 setter 将这本书提供给 VC,因为您在 viewDidLoad 中访问它。我会将 viewDidLoad 更改为这样的...

-(void)viewDidLoad
{
    self.managedObjectContext = [[NSManagedObjectContext alloc] init];
    self.managedObjectContext.parentContext = self.book.managedObjectContext;
    // We are in the main thread, so we can safely access the main MOC
    // Basically, move our object pointer to book into our local MOC.
    NSError * error = nil;
    Book *book = [self.managedObjectContext existingObjectWithID:self.book.objectID error:&error];
    // handle nil return and/or error
    self.book = book;
    // Now, your access to book will be in the local MOC, and any changes
    // you make to the book or book.author will all be confined to the local MOC.
}

现在,你所要做的就是打电话

[self.managedObjectContext save:&error];

在您的 saveAndDismiss 操作中。如果您不调用 save,则不会保存任何更改,它们都会自动消失。

编辑

请注意,上面的“保存”只是将对象状态移动到父上下文中。因此,“主” MOC 现在具有来自“子”的更改,但尚未将任何更改保存到磁盘。

于 2012-05-07T19:22:23.547 回答