【问题标题】:undo all changes made in the child view controller撤消在子视图控制器中所做的所有更改
【发布时间】:2012-05-13 16:45:53
【问题描述】:

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

【问题讨论】:

  • 我认为这里的问题不在于重新加载,问题是您将更改的作者姓名保存到实体中
  • 但我没有对更改进行分组,如何在此处撤消?
  • 它的撤消管理器默认行为
  • 但我在 VCBook 中设置了一个新的 undoManager。
  • 如果我推送一个新的视图控制器来编辑 authorName 并在返回 VCAuthor 时将更改的名称保存到实体。 VCBook 中的 undo 方法完全不会影响。

标签: iphone ios core-data nsmanagedobjectcontext nsundomanager


【解决方案1】:

需要考虑的几件事。首先,在这种情况下,我会使用单独的 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 现在具有来自“子”的更改,但尚未将任何更改保存到磁盘。

【讨论】:

  • 如果我使用单独的 MOC,这本书无法通过 [self.author addBookObject self.book] 添加给作者; .我不会将更改保存到 VCBook 中的持久存储。完成VCAuthor中的所有更改(如修改作者姓名、年龄等)然后保存在那里。
  • 对不起,我不明白您在此评论中想说什么。你做了三个不完整的陈述,我无法理解你试图描述什么问题。
  • 1st,如果我在单独的 MOC 中编辑这本书,我无法通过“[self.author addBookObject self.book];”将这本书添加给作者。因为它们不在同一个 MOC 中。 2、在VCBook中,“[self.managedObjectContext save:&error];”由于其他一些原因,这不是我想要的。 3、当点击 VCAuthor 中的保存按钮时,所有更改都将保存到持久存储中。
  • 您阅读我发布的代码了吗?首先,您一次只有一个视图控制器处于活动状态。根据您之前所说,这个特定的视图控制器正在编辑作者。其次,在我发布的代码中,正在使用的“当前书籍”对象位于同一个 MOC 中。最后,你的假设是错误的。保存作者上下文只是将这些更改推送到父 MOC。在 MOC 保存之前,它们不会被保存。
  • [self.managedObjectContext save:&error];此代码只是将更改保存到 parentContext 对吗?让我稍后再试,谢谢!
猜你喜欢
  • 2012-05-11
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2016-12-07
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多