3

我正在从另一个类调用我的 TableViewController 类中的一个方法。

要调用显示 tableview 的方法,我这样做:

TableViewController *tableVC = [[TableViewController alloc]init];
[tableVC setTableViewContent];

然后在 TableViewController.h

@interface TableViewController : UITableViewController <UITableViewDelegate, UITableViewDataSource>
{
NSMutableArray *nameArray;
}

-(void)setTableViewContent;
@property (nonatomic, strong) IBOutlet UITableView *tableView;

@end

表视图控制器.m

@implementation TableViewController
@synthesize tableView;


- (void)viewDidLoad
{ 
 nameArray = [[NSMutableArray alloc]init];
[super viewDidLoad];

}

-(void)setTableViewContent{


AppDelegate *appDelegate = (AppDelegate *)[[UIApplication sharedApplication] delegate];

for(int i=0;i< [appDelegate.businessArray count];i++)
{

    NSDictionary *businessDict = [[appDelegate.businessArray objectAtIndex:i] valueForKey:@"location"];


    nameArray = [appDelegate.businessArray valueForKey:@"name"];

}
NSLog(@"%@", nameArray);


  NSLog(@"tableview: %@", tableView);

// here tableview returns null
[tableView reloadData];


 }


- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
{

// Return the number of sections.
return 1;
}

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{

// Return the number of rows in the section.
return [nameArray count];
}

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
    NSLog(@"updating tableview...");
    static NSString *CellIdentifier = @"Cell";
    UITableViewCell *cell =[tableView dequeueReusableCellWithIdentifier:CellIdentifier forIndexPath:indexPath];

    // Configure the cell...
         cell.textLabel.text = [nameArray objectAtIndex:indexPath.row];

    return cell;
}

出于某种原因,当我尝试记录 tableview 时,它返回 null,因此 ReloadData 不起作用。代理和数据源在 IB 中正确连接,并且有一个 tableView 的引用出口。

知道这里发生了什么吗?提前致谢

4

3 回答 3

3

如果您将表视图控制器添加到容器视图中,那么您可以在 prepareForSegue 中获取对该控制器的引用。对于容器视图中的控制器,prepareForSegue 将在父控制器的 viewDidLoad 之前调用,因此您无需执行任何操作来调用它。在下面的示例中,我将 segue 称为“TableEmbed”——您需要在 IB 中为 segue 提供该标识符。

- (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender {
    if([segue.identifier isEqualToString:@"TableEmbed"]) {
        TableViewController *tableVC = (TableViewController *)segue.destinationViewController;
        [tableVC setTableViewContent];
    }
}

请注意 prepareForSegue:sender: 在调用任一控制器的 viewDidLoad 之前调用,因此您应该将数组的初始化移动到 setTableViewContent,并且您的 reloadTable 应该进入 viewDidLoad。

顺便说一句,我不清楚为什么要从其他班级调用 setTableContent 。为什么不将该方法中的所有代码移到表格视图控制器的 viewDidLoad 方法中呢?

于 2013-07-17T06:05:26.550 回答
0

我通过在以下位置创建“安全”重新加载方法解决了类似的情况UITableViewController

- (void)reloadTableViewData
{
    if ([self isViewLoaded])
        [self.tableView reloadData];
}

根据文档isViewLoaded

调用此方法会报告视图是否已加载。与 view 属性不同,如果视图不在内存中,它不会尝试加载视图。

因此,reloadTableViewData在任何时候调用表视图控制器都是安全的。

于 2014-01-10T04:49:41.893 回答
0

发生这种情况是因为您在 tableView 实际存在之前调用它的方法。简单地初始化该类并不会绘制表格本身,因此在实际创建表格之前使用 reloadData 并没有任何意义。

在这种情况下,您要做的是在调用 setTableViewContent 的任何类中创建您的 nameArray,然后通过自定义 init 方法或通过在加载该表视图控制器之前设置 tableVC.nameArray 将其传递。

我要做的是制作自定义初始化方法,例如- (id)initWithArray:(NSMutableArray *)nameArr

应该是这样的:

if (self = [super init]) {
    nameArray = [nameArr copy];
}
return self;

然后,您TableViewController *tableVC = [[TableViewController alloc]init];TableViewController *tableVC = [[TableViewController alloc]initWithArray:theNameArray];nameArray 放在 setTableViewContent 中的内容(您现在在调用表视图而不是表视图本身的同一类中生成)。

说得通?

于 2013-07-17T04:06:23.187 回答