Лично я думаю, что оба предложенных урока имеют большой недостаток, когда дело доходит до reuseIdentifier
.Если вы забыли назначить его в конструкторе интерфейсов или неправильно написали его, вы будете загружать перо каждый раз, когда вызывается cellForRowAtIndexPath
.
Джефф Ламарч пишет об этом и как исправить это в этом блоге почта .Помимо reuseIdentifier
он использует тот же подход, что и в документации Apple для Загрузка пользовательских ячеек табличного представления из файлов пера .
Прочитав все эти статьи, я пришел к следующему коду:
Редактировать: если вы ориентируетесь на iOS 5.0 и выше, вам нужно придерживаться Duane Fields'answer
@interface CustomCellWithXib : UITableViewCell
+ (NSString *)reuseIdentifier;
- (id)initWithOwner:(id)owner;
@end
@implementation CustomCellWithXib
+ (UINib*)nib
{
// singleton implementation to get a UINib object
static dispatch_once_t pred = 0;
__strong static UINib* _sharedNibObject = nil;
dispatch_once(&pred, ^{
_sharedNibObject = [UINib nibWithNibName:NSStringFromClass([self class]) bundle:nil];
});
return _sharedNibObject;
}
- (NSString *)reuseIdentifier
{
return [[self class] reuseIdentifier];
}
+ (NSString *)reuseIdentifier
{
// return any identifier you like, in this case the class name
return NSStringFromClass([self class]);
}
- (id)initWithOwner:(id)owner
{
return [[[[self class] nib] instantiateWithOwner:owner options:nil] objectAtIndex:0];
}
@end
UINib (доступный в iOS 4.0 и более поздних версиях) используется здесь как одиночный, потому что, хотя используется reuseIdentifier
, ячейка все еще переинициализируется относительно10 раз или около того.Теперь cellForRowAtIndexPath
выглядит так:
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
CustomCellWithXib *cell = [tableView dequeueReusableCellWithIdentifier:[CustomCellWithXib reuseIdentifier]];
if (cell == nil) {
cell = [[CustomCellWithXib alloc] initWithOwner:self];
}
// do additional cell configuration
return cell;
}