cocoa 默認(rèn)的cell風(fēng)格修改起來(lái)挺靈活的 先提供處自定義代碼 其實(shí)難點(diǎn)在于cell重用機(jī)制 供初學(xué)者參考
- ( UITableViewCell *)tableView:( UITableView *)tableView cellForRowAtIndexPath:( NSIndexPath *)indexPath
{
static NSString * showUserInfoCellIdentifier = @"ShowUserInfoCell" ;
UITableViewCell * cell = [tableView dequeueReusableCellWithIdentifier :showUserInfoCellIdentifier];
if (cell == nil )
{
// Create a cell to display an ingredient.
cell = [[[ UITableViewCell alloc ] initWithStyle : UITableViewCellStyleSubtitle
reuseIdentifier :showUserInfoCellIdentifier]
autorelease ];
UIImageView *leftico= [[[ UIImageView alloc ] init ] autorelease ];
leftico. tag = 11 ;
leftico. frame = CGRectMake ( 0 , 0 , 100 , 60 );
[leftico setContentMode : UIViewContentModeScaleAspectFit ];
UILabel *titles= [[[ UILabel alloc ] initWithFrame : CGRectMake ( 110 , 0 , 120 , 60 )] autorelease ];
[titles setBackgroundColor :[ UIColor clearColor ] ];
titles. tag = 22 ;
[cell addSubview :titles];
[cell addSubview :leftico];
cell. accessoryType = UITableViewCellAccessoryDetailDisclosureButton ;//添加其默認(rèn)的細(xì)節(jié)按鈕
}
NSUInteger row=[indexPath row ];
NSLog ( @"name == %@" ,[ [ self . listdata objectAtIndex :row] objectForKey : @"name" ]);
UIImageView *imageView11 = ( UIImageView *)[cell viewWithTag : 11 ]; //重新指向那片內(nèi)存
//[ [cell viewWithTag:1] removeFromSuperview];
imageView11. image = [ UIImage imageNamed : @"gongshang.png" ];
UILabel *titles22= ( UILabel *)[cell viewWithTag : 22 ];
titles22. text =[ [ self . listdata objectAtIndex :row] objectForKey : @"name" ];
// if (cell.textLabel.text isEqualToString:@" 工商銀行 ") {
// cell.imageView.image= [ UIImage imageNamed:@"bg.jpg" ] ;
// }
return cell;
下面有一網(wǎng)友做的例程 分析對(duì)比下 看看有什么收獲
我在寫(xiě)一個(gè)App的時(shí)候自定義了一個(gè)UITableViewCell,但是這個(gè)UITableView在運(yùn)行的時(shí)候出現(xiàn)了每6行數(shù)據(jù)就循環(huán)重復(fù)顯示的問(wèn)題,而直接使用cell.textLabel.text顯示是沒(méi)有這個(gè)問(wèn)題,以下是我實(shí)現(xiàn)的代碼。
- -(UITableViewCell*)tableView:(UITableView*)tableViewcellForRowAtIndexPath:(NSIndexPath*)indexPath
- {
- NSIntegersection=[indexPathsection];
- NSIntegerrow=[indexPathrow];
- UITableViewCell*cell;
- switch (section)
- {
- case 0:
- //dosomething.
- case 1:
- cell=[tableViewdequeueReusableCellWithIdentifier:@ "Cell" ];
- if (cell==nil)
- {
- cell=[[[UITableViewCellalloc]initWithStyle:UITableViewCellStyleDefaultreuseIdentifier:@ "Cell" ]autorelease];
- //Image
- UIImageView*image=[[UIImageViewalloc]initWithFrame:CGRectMake(0.0f,14.0f,45.0f,50.0f)];
- image.backgroundColor=[UIColorclearColor];
- image.image=[UIImageimageNamed:@ "folder.png" ];
- [cell.contentViewaddSubview:image];
- [imagerelease];
- //Label
- UILabel*titleLabel=[[UILabelalloc]initWithFrame:CGRectMake(45.0f,6.0f,214.0f,50.0f)];
- titleLabel.text=(NSString*)[(NSArray*)[self.categoryArrayobjectAtIndex:1]objectAtIndex:row];
- NSLog(@ "%@--%d" ,titleLabel.text,row);
- titleLabel.textAlignment=UITextAlignmentLeft;
- titleLabel.numberOfLines=3;
- titleLabel.tag=201;
- titleLabel.font=[UIFontboldSystemFontOfSize:14];
- [cell.contentViewaddSubview:titleLabel];
- [titleLabelrelease];
- }
- cell.accessoryType=UITableViewCellAccessoryDetailDisclosureButton;
- break ;
- }
- cell.selectionStyle=UITableViewCellSelectionStyleNone;
- return cell;
- }
google了一下,目前已有的解決方案是將
- cell=[tableViewdequeueReusableCellWithIdentifier:@ "Cell" ];
替換成
- cell=[tableViewcellForRowAtIndexPath:indexPath];
或
- cell=nil;
這們做的目的去掉Cell的重用機(jī)制,但是這種方法都會(huì)在后臺(tái)隨著表格滾動(dòng)一直在創(chuàng)建cell,通過(guò)上面源代碼中Label定義里那句NSLog在控制臺(tái)輸出就可以看到,雖然會(huì)自動(dòng)回收內(nèi)存,但肯定也會(huì)給系統(tǒng)帶來(lái)不小開(kāi)銷,所以不到萬(wàn)一得以還是不會(huì)用的。
還有一種解決方案是自己定義Cell數(shù)組,在 tableView:tableView cellForRowAtIndexPath:中進(jìn)設(shè)置要顯示的cell,這是手工維護(hù)cell的一種方式,對(duì)大數(shù)據(jù)量的情況肯定是不適用的,不過(guò)也能算得上是一種思路吧,可以參考一下。其代碼如下:
- //在構(gòu)造函數(shù)里定義cell數(shù)組
- for ( int i=0;i<31;i++)
- {
- static NSString*MyBookMarkIdentifier=@ "CityMangerCell" ;
- cityCell[i]=[[CityMangerCellalloc]initWithFrame:CGRectZeroreuseIdentifier:MyBookMarkIdentifierinitIndex:i];
- }
- //使用它
- -(UITableViewCell*)tableView:(UITableView*)tableViewcellForRowAtIndexPath:(NSIndexPath*)indexPath
- {
- if ((0<=indexPath.row)&&(indexPath.row<31))
- return cityCell[indexPath.row];
- return nil;
- }
后來(lái)我仔細(xì)分析了一下程序,找到了問(wèn)題所在:
原因是在if (cell == nil)判斷內(nèi)部不應(yīng)該對(duì)其label進(jìn)行賦值,即不使用這句:
- titleLabel.text =(NSString*)[(NSArray*)[self.categoryArrayobjectAtIndex:1]objectAtIndex:row];
正確的做法應(yīng)該是在if (cell == nil){}判斷后面進(jìn)行賦值。即
- if( cell ==nil)
- {
- ....
- }
- UILabel* l1 =(UILabel*)[cell.contentViewviewWithTag:201];
- l1.text =(NSString*)[(NSArray*)[self.categoryArrayobjectAtIndex:1]objectAtIndex:row];
分析原因如下:
UITableView中被實(shí)例化的cell個(gè)數(shù)由屏高和每個(gè)cell的高度決定,因?yàn)槲业腸ell高度設(shè)置為80,一屏只能 顯示6個(gè)Cell(只有6個(gè)cell被實(shí)例化),也就是只有這6個(gè)cell才會(huì)執(zhí)行if (cell == nil){}中的代碼,從第6行往后的cell都是重用的這6個(gè)cell,也就是說(shuō)從第7行開(kāi)始將不會(huì)執(zhí)行if (cell = nil){}中的代碼,當(dāng)UITableView需要繪制第7行cell的時(shí)候,會(huì)取得第1個(gè)cell進(jìn)行重用,如果我們不把原來(lái)第1行cell中的 Label內(nèi)容進(jìn)行修改,那么第7行將完全顯示第1行中的內(nèi)容,所以才會(huì)在第6行之后開(kāi)始出現(xiàn)數(shù)據(jù)重復(fù)的情況。
現(xiàn)在我將Label內(nèi)容設(shè)置的代碼放到if (cell == nil){}之后,它將會(huì)對(duì)每一個(gè)被重用的cell的Label進(jìn)行設(shè)定,也就不會(huì)再出現(xiàn)cell內(nèi)容重復(fù)的現(xiàn)象。
希望這個(gè)問(wèn)題的解決過(guò)程會(huì)對(duì)大家有所幫助。
本文出自 “ 一葉障目 ” 博客,請(qǐng)務(wù)必保留此出處 http://ddkangfu.blog.51cto.com/311989/465557
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
