以下是委托的viewForTableColumn方法。我基于列表视图中的选择在数据源中动态创建表列。
NSDictionary* rowData = [[self tableData] objectAtIndex:row];
NSString* identifier = [tableColumn identifier];
NSTableCellView* result = [tableView makeViewWithIdentifier:@"myCellView" owner:self];
if (result == nil) {
result = [[NSTableCellView alloc] initWithFrame:NSMakeRect(0, 0, 90.0, 10.0)];
_textField = [[NSTextField alloc] initWithFrame:NSMakeRect(0, 0, 90.0, 10.0)];
[result setTextField:_textField];
[[result textField] setStringValue:[rowData objectForKey:identifier]];
}
else {
[[result textField] setStringValue:[rowData objectForKey:identifier]];
}
NSLog(@"result text field: %@", [[result textField] stringValue]);
return result;
现在在
-(void)tableView:(NSTableView *)tableView didAddRowView:(NSTableRowView *)rowView forRow:(NSInteger)row {
NSLog(@"did add: %ld", row);
NSTableCellView* aView = [rowView viewAtColumn:0];
NSLog(@"%@", [[aView textField]stringValue]);
NSLog(@"%@",[[[rowView viewAtColumn:0 ] textField] stringValue]);
}
textField是一个僵尸。是什么赋予了?谢谢你的帮助。
答案 0 :(得分:1)
必须在窗口控制器中获取NSTableCellView的引用(IBOutlet)。多数民众赞成,没有别的。现在我可以通过NSTableView委托中的标识符访问它;即使在删除所有列并向表视图添加新列之后,也会保留引用。
现在处理300-3000行的表格中非常糟糕的tableview性能!那是另一天。
答案 1 :(得分:0)
我唯一能想到的就是你做的时候:
_textField = [[NSTextField alloc] initWithFrame:NSMakeRect(0, 0, 90.0, 10.0)];
您正在释放_textField
中之前的内容。