關(guān)于UITableView的兩種重用Cell方法的區(qū)別

在iOS中有兩種創(chuàng)建cell的方式

- (nullable __kindof UITableViewCell *)dequeueReusableCellWithIdentifier:(NSString *)identifier; 
 // Used by the delegate to acquire an already allocated cell, in lieu of allocating a new one.
- (__kindof UITableViewCell *)dequeueReusableCellWithIdentifier:(NSString *)identifier forIndexPath:(NSIndexPath *)indexPath NS_AVAILABLE_IOS(6_0); 
// newer dequeue method guarantees a cell is returned and resized properly, assuming identifier is registered

在iOS 6中dequeueReusableCellWithIdentifier:被dequeueReusableCellWithIdentifier:forIndexPath:所取代。如此一來,在表格視圖中創(chuàng)建并添加UITableViewCell對象會變得更為精簡而流暢。而且使用dequeueReusableCellWithIdentifier:forIndexPath:一定會返回cell,系統(tǒng)在默認(rèn)沒有cell可復(fù)用的時(shí)候會自動(dòng)創(chuàng)建一個(gè)新的cell出來。

使用dequeueReusableCellWithIdentifier:forIndexPath:的話,必須和下面的兩個(gè)配套方法配合起來使用:

// Beginning in iOS 6, clients can register a nib or class for each cell.
// If all reuse identifiers are registered, use the newer -dequeueReusableCellWithIdentifier:forIndexPath: 
to guarantee that a cell instance is returned.
// Instances returned from the new dequeue method will also be properly sized when they are returned.
- (void)registerNib:(nullable UINib *)nib forCellReuseIdentifier:(NSString *)identifier NS_AVAILABLE_IOS(5_0);
- (void)registerClass:(nullable Class)cellClass forCellReuseIdentifier:(NSString *)identifier NS_AVAILABLE_IOS(6_0);

1、如果是用NIB自定義了一個(gè)Cell,那么就調(diào)用registerNib:forCellReuseIdentifier:
2、如果是用代碼自定義了一個(gè)Cell,那么就調(diào)用registerClass:forCellReuseIdentifier:
以上這兩個(gè)方法可以在創(chuàng)建UITableView的時(shí)候進(jìn)行調(diào)用。

這樣在tableView:cellForRowAtIndexPath:方法中就可以省掉下面這些代碼:

static NSString *CellIdentifier = @"Cell";
if (cell == nil) 
    cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:CellIdentifier];

取而代之的是下面這句代碼:

UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:@"Cell" forIndexPath:indexPath];  
一.使用nib

1、xib中指定cell的Class為自定義cell的類型(不是設(shè)置File's Owner的Class)
2、調(diào)用registerNib:forCellReuseIdentifier:向數(shù)據(jù)源注冊cell

[_tableView registerNib:[UINib nibWithNibName:@"CustomCell" bundle:nil] forCellReuseIdentifier:kCellIdentify];   

3、在tableView:cellForRowAtIndexPath:中使用dequeueReusableCellWithIdentifier:forIndexPath:獲取重用的cell,如果沒有重用的cell,將自動(dòng)使用提供的nib文件創(chuàng)建cell并返回(如果使用dequeueReusableCellWithIdentifier:需要判斷返回的是否為空)

 CustomCell *cell = [_tableView dequeueReusableCellWithIdentifier:kCellIdentify forIndexPath:indexPath];  

4、獲取cell時(shí)如果沒有可重用cell,將創(chuàng)建新的cell并調(diào)用其中的awakeFromNib方法

二、不使用NIB

1、重寫自定義cell的initWithStyle:withReuseableCellIdentifier:方法進(jìn)行布局
2、注冊cell

[_tableView registerClass:[CustomCell class] forCellReuseIdentifier:kCellIdentify];   

3、在tableView:cellForRowAtIndexPath:中使用dequeueReusableCellWithIdentifier:forIndexPath:獲取重用的cell,如果沒有重用的cell,將自動(dòng)使用提供的class類創(chuàng)建cell并返回

CustomCell *cell = [tableView dequeueReusableCellWithIdentifier:kCellIdentify forIndexPath:indexPath];   

4、獲取cell時(shí)如果沒有可重用的cell,將調(diào)用cell中的initWithStyle:withReuseableCellIdentifier:方法創(chuàng)建新的cell

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容