iOS tableView的cell的重用問題

常規配置如下 當超過tableView顯示的範圍的時候 後面顯示的內容將會和前面重複
// 這樣配置的話超過頁面顯示的內容會重複出現
- (UITableViewCell )tableView:(UITableView )tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
// 定義唯一標識
static NSString *CellIdentifier = @”Cell”;
// 通過唯一標識創建cell實例
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];
// 判斷爲空進行初始化 –(當拉動頁面顯示超過主頁面內容的時候就會重用之前的cell,而不會再次初始化)
if (!cell) {
cell = [[UITableViewCell alloc]initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:CellIdentifier];
}
// 對cell 進行簡單地數據配置
cell.textLabel.text = @”text”;
cell.detailTextLabel.text = @”text”;
cell.imageView.image = [UIImage imageNamed:@”4.png”];

return cell;

}

//通過以下3方案可以解決

方案一 取消cell的重用機制,通過indexPath來創建cell 將可以解決重複顯示問題 不過這樣做相對於大數據來說內存就比較吃緊了
// 方案一 通過不讓他重用cell 來解決重複顯示
- (UITableViewCell )tableView:(UITableView )tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
// 定義唯一標識
static NSString *CellIdentifier = @”Cell”;
// 通過indexPath創建cell實例 每一個cell都是單獨的
UITableViewCell *cell = [tableView cellForRowAtIndexPath:indexPath];
// 判斷爲空進行初始化 –(當拉動頁面顯示超過主頁面內容的時候就會重用之前的cell,而不會再次初始化)
if (!cell) {
cell = [[UITableViewCell alloc]initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:CellIdentifier];
}
// 對cell 進行簡單地數據配置
cell.textLabel.text = @”text”;
cell.detailTextLabel.text = @”text”;
cell.imageView.image = [UIImage imageNamed:@”4.png”];

return cell;

}

方案二 讓每個cell都擁有一個對應的標識 這樣做也會讓cell無法重用 所以也就不會是重複顯示了 顯示內容比較多時內存佔用也是比較多的和方案一類似
// 方案二 同樣通過不讓他重用cell 來解決重複顯示 不同的是每個cell對應一個標識
- (UITableViewCell )tableView:(UITableView )tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
// 定義cell標識 每個cell對應一個自己的標識
NSString *CellIdentifier = [NSString stringWithFormat:@”cell%ld%ld”,indexPath.section,indexPath.row];
// 通過不同標識創建cell實例
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];
// 判斷爲空進行初始化 –(當拉動頁面顯示超過主頁面內容的時候就會重用之前的cell,而不會再次初始化)
if (!cell) {
cell = [[UITableViewCell alloc]initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:CellIdentifier];
}
// 對cell 進行簡單地數據配置
cell.textLabel.text = @”text”;
cell.detailTextLabel.text = @”text”;
cell.imageView.image = [UIImage imageNamed:@”4.png”];

return cell;

}

方案三 只要最後一個顯示的cell內容不爲空,然後把它的子視圖全部刪除,等同於把這個cell單獨出來了 然後跟新數據就可以解決重複顯示
// 方案三 當頁面拉動需要顯示新數據的時候,把最後一個cell進行刪除 就有可以自定義cell 此方案即可避免重複顯示,又重用了cell相對內存管理來說是最好的方案 前兩者相對比較消耗內存
- (UITableViewCell )tableView:(UITableView )tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
// 定義唯一標識
static NSString *CellIdentifier = @”Cell”;
// 通過唯一標識創建cell實例
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];

// 判斷爲空進行初始化  --(當拉動頁面顯示超過主頁面內容的時候就會重用之前的cell,而不會再次初始化)
if (!cell) {
    cell = [[UITableViewCell alloc]initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:CellIdentifier];
}
else//當頁面拉動的時候 當cell存在並且最後一個存在 把它進行刪除就出來一個獨特的cell我們在進行數據配置即可避免
{
    while ([cell.contentView.subviews lastObject] != nil) {
        [(UIView *)[cell.contentView.subviews lastObject] removeFromSuperview];
    }
}
// 對cell 進行簡單地數據配置
cell.textLabel.text = @"text";
cell.detailTextLabel.text = @"text";
cell.imageView.image = [UIImage imageNamed:@"4.png"];

return cell;

}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章