前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >iOS开发-1.UITableView你会用吗?

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

作者头像
孙寅
发布2020-06-03 09:23:34
7790
发布2020-06-03 09:23:34
举报
文章被收录于专栏:宜达数字宜达数字

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

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

Paste_Image.png

设置行高:

代码语言:javascript
复制
table.rowHeight =70;

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

Paste_Image.png

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

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

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

Paste_Image.png

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

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

最新cell的循环利用方法:

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

Paste_Image.png

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

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

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

代码语言:javascript
复制
@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

代码语言:javascript
复制
@protocol UITableViewDelegate<NSObject,UIScrollViewDelegate>

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

代码语言:javascript
复制
// 监听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

代码语言:javascript
复制
- (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

代码语言:javascript
复制
- (void)ViewDidLoad
{
    [Super ViewDidLoad];
    [self.tableView setSeparatorInset:UIEdgeInsetsZero];
    [self.tableView setLayoutMargins:UIEdgeInsetsZero];
}

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

代码语言:javascript
复制
- (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的背景颜色(两种方法)

代码语言:javascript
复制
cell.backGroundColor = [UIColor redColor];

另一种设置方法cell.backgroundView

Paste_Image.png

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

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

代码语言:javascript
复制
 // 设置指示器(灰色小箭头)
 cell.accessoryType=UITableViewCellAccessoryDisclosureIndicator;

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

代码语言:javascript
复制
cell.accessoryView = [[UIImageView alloc] initWithImage:];
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • pragma mark - 创建、设置cell
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档