常規(guī)配置如下 當超過tableView顯示的范圍的時候 后面顯示的內(nèi)容將會和前面重復
// 這樣配置的話超過頁面顯示的內(nèi)容會重復出現(xiàn)
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
// 定義唯一標識
static NSString *CellIdentifier = @"Cell";
// 通過唯一標識創(chuàng)建cell實例
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];
// 判斷為空進行初始化 --(當拉動頁面顯示超過主頁面內(nèi)容的時候就會重用之前的cell蒿辙,而不會再次初始化)
if (!cell) {
cell = [[UITableViewCell alloc]initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:CellIdentifier];
}
// 對cell 進行簡單地數(shù)據(jù)配置
cell.textLabel.text = @"text";
cell.detailTextLabel.text = @"text";
cell.imageView.image = [UIImage imageNamed:@"4.png"];
return cell;
}
//通過以下3方案可以解決
方案一 取消cell的重用機制管毙,通過indexPath來創(chuàng)建cell 將可以解決重復顯示問題 不過這樣做相對于大數(shù)據(jù)來說內(nèi)存就比較吃緊了
// 方案一 通過不讓他重用cell 來解決重復顯示
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
// 定義唯一標識
static NSString *CellIdentifier = @"Cell";
// 通過indexPath創(chuàng)建cell實例 每一個cell都是單獨的
UITableViewCell *cell = [tableView cellForRowAtIndexPath:indexPath];
// 判斷為空進行初始化 --(當拉動頁面顯示超過主頁面內(nèi)容的時候就會重用之前的cell关拒,而不會再次初始化)
if (!cell) {
cell = [[UITableViewCell alloc]initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:CellIdentifier];
}
// 對cell 進行簡單地數(shù)據(jù)配置
cell.textLabel.text = @"text";
cell.detailTextLabel.text = @"text";
cell.imageView.image = [UIImage imageNamed:@"4.png"];
return cell;
}
方案二 讓每個cell都擁有一個對應(yīng)的標識 這樣做也會讓cell無法重用 所以也就不會是重復顯示了 顯示內(nèi)容比較多時內(nèi)存占用也是比較多的和方案一類似
// 方案二 同樣通過不讓他重用cell 來解決重復顯示 不同的是每個cell對應(yīng)一個標識
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
// 定義cell標識 每個cell對應(yīng)一個自己的標識
NSString *CellIdentifier = [NSString stringWithFormat:@"cell%ld%ld",indexPath.section,indexPath.row];
// 通過不同標識創(chuàng)建cell實例
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];
// 判斷為空進行初始化 --(當拉動頁面顯示超過主頁面內(nèi)容的時候就會重用之前的cell,而不會再次初始化)
if (!cell) {
cell = [[UITableViewCell alloc]initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:CellIdentifier];
}
// 對cell 進行簡單地數(shù)據(jù)配置
cell.textLabel.text = @"text";
cell.detailTextLabel.text = @"text";
cell.imageView.image = [UIImage imageNamed:@"4.png"];
return cell;
}
方案三 只要最后一個顯示的cell內(nèi)容不為空胳赌,然后把它的子視圖全部刪除牢撼,等同于把這個cell單獨出來了 然后跟新數(shù)據(jù)就可以解決重復顯示
// 方案三 當頁面拉動需要顯示新數(shù)據(jù)的時候,把最后一個cell進行刪除 就有可以自定義cell 此方案即可避免重復顯示疑苫,又重用了cell相對內(nèi)存管理來說是最好的方案 前兩者相對比較消耗內(nèi)存
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
// 定義唯一標識
static NSString *CellIdentifier = @"Cell";
// 通過唯一標識創(chuàng)建cell實例
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];
// 判斷為空進行初始化 --(當拉動頁面顯示超過主頁面內(nèi)容的時候就會重用之前的cell熏版,而不會再次初始化)
if (!cell) {
cell = [[UITableViewCell alloc]initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:CellIdentifier];
}
else//當頁面拉動的時候 當cell存在并且最后一個存在 把它進行刪除就出來一個獨特的cell我們在進行數(shù)據(jù)配置即可避免
{
while ([cell.contentView.subviews lastObject] != nil) {
[(UIView *)[cell.contentView.subviews lastObject] removeFromSuperview];
}
}
// 對cell 進行簡單地數(shù)據(jù)配置
cell.textLabel.text = @"text";
cell.detailTextLabel.text = @"text";
cell.imageView.image = [UIImage imageNamed:@"4.png"];
return cell;
}