iOS开发-1.UITableView你会用吗?

前一段时间,公司招聘了一个新员工,界面做出来了,但是很卡,我看完他写的代码,发现没有对UITableViewCell进行循环使用,而且在UITableView代理方法中,创建了很多并没有什么用的对象,一些调用频繁的方法也没有很好地处理。

首先创建一个UITableView.设置数据源为控制器,并实现数据源方法。


Paste_Image.png

设置行高:

table.rowHeight =70;

既然遵守数据源方法,那就实现数据源方法

Paste_Image.png

返回cell的方法,苹果默认— 用到时再创建,但是会频繁的创建,销毁,造成浪费

所以优化—里面的代码就先去缓存池子中寻找:(找不到)我们创建

注意点:关于cell的数据,不要放置在判断里面,因为这个方法只有在一开始创建cell的时候才会调用,后面循环利用的时候就会导致数据错乱。

Paste_Image.png

被static修饰的局部变量:只会初始化一次,在整个程序运行中,只有一份内存。

 定义重用标识:static NSString*ID = @"cell";
cell的样式有好几种:(红色代表常用)
 UITableViewCellStyleDefault      默认样式
 UITableViewCellStyleValue1,    样式一
 UITableViewCellStyleValue2,    样式二
UITableViewCellStyleSubtitle  带有子标题模式的样式

最新cell的循环利用方法:

利用标识来注册一个带有标识的cell:(前提:通过stroyBoard创建的UITableView,那么要拖线拿到它)

Paste_Image.png

这个只注册一次,所以在ViewDidLoad中注册

好处:不用判断缓存池子的cell是否为空,只要注册了cell,那么创建出来绝对有值。

TableView代理方法:
代理方法肯定要遵守代理协议:

@interfaceViewController ()<UITableViewDelegate>
Paste_Image.png

常用代理方法:

Paste_Image.png

每一行的高度也可以这样设置— self.tableView.rowHeight = 100;

当时上面的高度方法可以搞定不一样的cell高度设置

这里引出一个估计cell高度的方法:(针对微博方面)

Paste_Image.png

这里引出两个样式:(也可以在stroyboard中选择)

Paste_Image.png

这个也是代理方法:与那个返回头部高度容易混淆,要记住返回值类型

Paste_Image.png

tableView的代理方法,默认继承了UIScrollViewDelegate

@protocol UITableViewDelegate<NSObject,UIScrollViewDelegate>

所以可以直接使用这个方法监听tableView的滚动

// 监听tableView 的滚动
- (void)scrollViewDidScroll:(UIScrollView*)scrollView

说到TableViewController,在MainStoryBoard中:
一般新手会直接将类型名改为UITableViewController,这样就导致错误出现

Paste_Image.png

注意点:错误将UIViewController当做UITableViewController来用

其实添加

Paste_Image.png
Paste_Image.png

做好上面这一步在UITableViewController里面:
默认:
self.view == self.tableView,是同一个对象。
默认:
self.tableView.dateSource= self;
self.tableView.delegate = self

cell的循环利用(第三种思路)

Paste_Image.png

选中cell,点击重用标识

这样在代码中,就可以省略掉:那个判断语句:if(cell== nil){创建cell的方法}

以后在tableView中开发一个cell

Paste_Image.png

pragma mark - 创建、设置cell

抽出cell

- (UITableViewCell *)cell:(UITableView*)tableView indexPath:(NSIndexPath*)indexPath
{
    //0.重用标识
    //被static修饰的局部变量:只会初始化一次,在整个程序运行过程中,只有一份内存
    staticNSString*ID = @"cell";
    //1.先根据cell的标识去缓存池中查找可循环利用的cell
    UITableViewCell*cell = [tableViewdequeueReusableCellWithIdentifier:ID];
    //2.覆盖数据
    cell.textLabel.text = [NSString stringWithFormat:@"cell- %zd", indexPath.row];
    returncell;
}

效果图

Paste_Image.png

tableView的常见设置:


Paste_Image.png

从iOS7以后,分割线变成了两变都有间距,所以如果要达到一条线贯穿整个cell,那就添加一个View,设置它粘着cell的底部。。
添加一个UIView,设置左右下部约束,高度约束设为1,就可以看到一条线贯穿整个cell的底部了。

Paste_Image.png
- (void)ViewDidLoad
{
    [Super ViewDidLoad];
    [self.tableView setSeparatorInset:UIEdgeInsetsZero];
    [self.tableView setLayoutMargins:UIEdgeInsetsZero];
}

在cell将要显示出来的方法中执行下面的代码

- (void)tableView:(UITableView *)tableView willDisplayCell:(UITableViewCell *)cell forRowAtIndexPath:(NSIndexPath *)indexPath
{
    [cell setSeparatorInset:UIEdgeInsetsZero];
    [cell setLayoutMargins:UIEdgeInsetsZero];
}

cell的样式设置
注意:SeparatorStyleNone取消选中样式,上面还有一个,长得很像

Paste_Image.png

系统自带的方法:只能控制cell的颜色选中为灰色,或者没有。在iOS6之前是可以实现的

Paste_Image.png

如果想自定义选中cell的背景颜色:(也可以设置图片,UIImage等等,都可以设置)

Paste_Image.png

如果设置不选中cell的背景颜色(两种方法)

cell.backGroundColor = [UIColor redColor];

另一种设置方法cell.backgroundView

Paste_Image.png

以上两种都可以,但是后面的VIew优先级比较高

cell的右边展示例如箭头,加号等

 // 设置指示器(灰色小箭头)
 cell.accessoryType=UITableViewCellAccessoryDisclosureIndicator;

如果想自定义,例如美工做一个漂亮的指示器图片(当然按钮也是可以的)

cell.accessoryView = [[UIImageView alloc] initWithImage:];
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,716评论 4 364
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,558评论 1 294
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,431评论 0 244
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,127评论 0 209
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,511评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,692评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,915评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,664评论 0 202
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,412评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,616评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,105评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,424评论 2 254
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,098评论 3 238
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,096评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,869评论 0 197
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,748评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,641评论 2 271

推荐阅读更多精彩内容