在我的应用程序中,我在表格 View 中列出了核心数据条目。我想允许用户使用以模式方式呈现为表单 View 的详细 View 来编辑记录。我在编辑记录时观察到异常行为。
流程:
- 用户加载带有记录的 TableView 。 -工作
- 用户选择一条记录进行编辑。 -工作
- 用户在呈现为模态表单 View 的 View Controller 中编辑记录。 -工作
- 用户保存编辑并关闭表单 View 。 -工作
- Tableview 显示了先前编辑的记录的正确更改。 -工作
- 用户重复步骤 2 - 4 选择不同的记录进行编辑。 -工作
- Tableview 显示所有记录的正确数据。 - 不工作。
在第 7 步,表格 View 将第一个 编辑记录的显示恢复到其原始状态。随后的记录编辑会导致所有先前的编辑恢复到其原始状态。如果 tableview 被关闭并重新加载,则记录是正确的,显示所有编辑。
我在 tableview 的 ViewWillAppear 方法中使用了 [tableview reload],但是当模态表单 View Controller 被关闭时它似乎没有被触发。
在我的 tableviewcontroller 代码中:
-(void)viewWillAppear:(BOOL)animated
{
[self.tableView reloadData];
}
四处寻找,我还没有找到解决方案,希望有人能指出我正确的方向。
谢谢!
最佳答案
当您呈现模态视图时,主视图 Controller 的 View 永远不会消失。因此,在您关闭模态视图后,将不会调用 viewWillAppear()。
您可以尝试在模态视图中实现自定义委托(delegate)函数,并将其设置在主视图 Controller 中,当您的数据更新时,触发委托(delegate)函数以重新加载位于主视图 Controller 中的 tableView。
了解什么是 iOS 中的委托(delegate)函数,以及
如何创建委托(delegate)函数是这样的:
在您的 ModalView.h 中:
// define the protocol for the delegate @protocol ModelViewDelegate <NSObject> - (void) didUpdateData; @end @interface ModalView: ViewController { //create a delegate instance id delegate; } // define delegate instance @property (nonatomic, assign) id <ModelViewDelegate> delegate;
在你的 modalView.m 中:
@synthesize delegate;
然后在你的函数中,将委托函数放在你需要触发的地方,例如:
- (void) updateDataIntoDatabase{ .... //Update work done. [self.delegate didUpdateData]; //dismiss your modalView; }
因此,在您的 MainViewController.h 中,
#import ModalView.h
和
@interface ModalView: ViewController <ModelViewDelegate > {
...
}
在您的 MainViewController.m 中,您将收到一条警告,提示您需要实现您已声明的委托(delegate)函数。所以,设置委托(delegate)函数,做你喜欢做的事情:
- (void) didUpdateData{
[self.tableView reloadData];
}
在实例化 modalView 实例后,不要忘记将 modelView 委托(delegate)设置为 self。如果不是,您的委托(delegate)函数将不会被触发。
modalView.delegate = self;
关于关闭模态后 iOS TableView 重新加载,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24544078/