ios之TableViewCell重用機制避免重複顯示問題

來源:互聯網
上載者:User

標籤:uitableviewcell   tableviewcell重用機制避免重   

常規配置如下 當超過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;}
以上都是個人理解,本人也是菜鳥,有理解不對的地方希望大家指出,同時也希望能對大家起到一定的協助!! Thank you!

ios之TableViewCell重用機制避免重複顯示問題

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.