0

我有一个包含许多视图和一个表格视图的视图控制器。

tableview 的单元格是自定义的,因此还有另一个类用于设置单元格。每个单元格中都有一个按钮。此按钮的图像根据单元格的内容而变化(此内容从数据库中读取)。

基本上,当用户按下按钮时,它会将自身更改为另一个图像,将新状态写入 DB,但 tableview 不会自动更新。

按钮的方法在自定义单元格类中,所以我尝试实例化我的视图控制器(带有 tableview 的那个)并执行一种方法来更新视图和 tableview 中的一些标签:

ViewControllerWithTable *vc = [[ViewControllerWithTable alloc] init];
[vc updateEverything];

但这不起作用。从相同的“ViewControllerWithTable”(添加重新加载按钮)调用的相同“updateEverything”方法完美运行。在 viewWillAppear 方法中添加“[tableView reloadData]”将不起作用,因为所有操作都在同一个视图中完成。

我错过了什么?

编辑:添加一些代码更清楚。

这是我用来更新表格视图的方法。它位于带有嵌入式 tableview 的 ViewController 内,当由其中一个视图中的按钮触发时,它可以工作:

- (void) updateEverything {
    // lots of DB writing and reading, plus label text changing inside all the views
    [tableView reloadData];

}

这是按钮按下的 IBAction,它位于自定义单元格类中:

-(void) btnPresaPressed:(UIButton *)sender {
    AppDelegate *deleg = (AppDelegate *)[[UIApplication sharedApplication] delegate];
    deleg.did = sender.tag;
    NSString *s1 = NSLocalizedString(@"ALERT_TITLE", nil);
    NSString *s2 = NSLocalizedString(@"ALERT_BODY", nil);
    NSString *s3 = NSLocalizedString(@"YES", nil);
    NSString *s4 = NSLocalizedString(@"NO", nil);
    UIAlertView *alertView = [[UIAlertView alloc] initWithTitle:s1
                                                        message:s2
                                                       delegate:self
                                              cancelButtonTitle:s4
                                              otherButtonTitles:s3, nil];
    [alertView setTag:1];
    [alertView show];

}

此方法显示一个调用另一个方法的警报视图,始终在自定义单元格类中:

- (void)alertView:(UIAlertView *)alertView didDismissWithButtonIndex:(NSInteger)buttonIndex {
    AppDelegate *deleg = (AppDelegate *)[[UIApplication sharedApplication] delegate];
    DbOperations *db = [[DbOperations alloc] init];
    NSString *alrtTitle = [alertView buttonTitleAtIndex:buttonIndex];
    NSString *s3 = NSLocalizedString(@"YES", nil);
    NSString *s4 = NSLocalizedString(@"NO", nil);
    switch (alertView.tag) {
        case 1:
            //
            break;
        case 2:
            if ([alrtTitle isEqualToString:s3]) {
                // DB writing and reading
                ViewControllerWithTable *vc = [[ViewControllerWithTable alloc] init];
                [vc updateEverything];
            } else if ([alrtTitle isEqualToString:s4]){
                //

            }
            break;
        case 3:
            if ([alrtTitle isEqualToString:s3]) {
                //
            }
            break;
        default:
            break;
    }

}

在这种情况下,updateEverything 方法不起作用。

4

3 回答 3

3

添加更多代码后编辑:

在以下几行中:

        if ([alrtTitle isEqualToString:s3]) {
            // DB writing and reading
            ViewControllerWithTable *vc = [[ViewControllerWithTable alloc] init];
            [vc updateEverything];

您正在实例化一个与显示表格视图的原始视图控制器完全无关的新视图控制器。因此,您将更新消息发送到错误的对象。

你需要的是一种机制,让你的单元知道哪个是正确的控制器来发送消息。

一种简单的解决方案是使用NSNotificationCenter

  1. 视图控制器为某种通知注册自己:

    [[NSNotificationCenter defaultCenter]
    addObserver:self
    selector:@selector(updateEverything:)
    name:kCellSentUpdateMessageNotification
    object:nil];
    
  2. 您的单元格发送通知,而不是直接调用消息:

    [[NSNotificationCenter defaultCenter] postNotificationName:kCellSentUpdateMessageNotification object:nil];
    

老答案:

你应该打电话

  [self.tableView reloadData]

从您的updateEverything方法实现。这将重新加载表数据,有效地更新其行外观。updateEverything显然,当连续点击按钮以使其工作时,应调用该方法。

如果这不起作用,请提供更多代码。

于 2012-06-05T08:24:30.130 回答
0

你有没有尝试把

[[self tableView] reloadData];

我记得我遇到过这样的问题,上面的这条线解决了我的问题。

于 2012-06-05T08:29:13.230 回答
0

这是你的问题:

按钮的方法在自定义单元格类中,所以我尝试实例化我的视图控制器(带有 tableview 的那个)并执行一种方法来更新视图和 tableview 中的一些标签:

您创建了一个全新的视图控制器,它不了解您的 tableview。最好的办法是在您的单元格子类中创建一个属性,并在您设置单元格时将其设置到您的视图控制器。然后您可以在该属性上调用您的 updateEverything 方法。

于 2012-06-05T08:43:51.697 回答