TableView和性能优化
data:image/s3,"s3://crabby-images/90fd9/90fd93461417ae3fa447c2f616ef98541ec663c7" alt=""
一:UITableView
1、UITableViewController继承于UIViewController,内部的tableView就是控制器的self.view
2、UITableView的性能优化:
1)、每当一个cell进入视野范围内就会调用一次-cellForRowAtIndexPath:这个方法,在这个方法里就会创建一个新的cell,这样在滚动tableView时就会不断的创建新的cell增加内存开销,要进一步优化。
优化思路:
搞一个缓存池,把tableview可视范围内已经创建的cell放在缓存池,当再次滚动tableView时在可视范围内重新出现的cell,先去缓存池中找看有没有可用的cell,如果没有的话再创建cell。离开屏幕的cell如果不放在缓存池会被销毁。
data:image/s3,"s3://crabby-images/61d17/61d176a3f4ada6898de2c016b21c4145a1635452" alt=""
注意: static NSString *identifier = @"cell";静态局部变量在只占一份内存,但不会改变作用域。
利用注册方法创建cell
注册方法特点:只能注册一次,并且在缓存池循环利用之前,也不能确定cell样式。
例如:想显示cell.detailLabel都显示不了。
data:image/s3,"s3://crabby-images/13e90/13e90abf90cbc789f432eef43e0dced8424f0b27" alt=""
3、UITableView的索引条
当滚动的时候上面的
data:image/s3,"s3://crabby-images/3f5e9/3f5e98176fcf19b5da73ec2b8e835538bbdeba89" alt=""
data:image/s3,"s3://crabby-images/2fb98/2fb98215e3feb9fe5987efa7dc4828ffeed49c42" alt=""
data:image/s3,"s3://crabby-images/4c824/4c8243708451a522595d0b1077ea6a005f0d0d3e" alt=""
4、字典转模型框架
data:image/s3,"s3://crabby-images/bd2d0/bd2d084c99995451fbd9df9bd19dad87767bc74f" alt=""
5、用代码创建cell或通过xib方法自定义cell
该方法根据先从缓存池取相应的cell,取不到的话通过判断不存在就创建cell
data:image/s3,"s3://crabby-images/ee0cd/ee0cdeab4fd25d40d71942f06f98af6ca83ba937" alt=""
data:image/s3,"s3://crabby-images/72c85/72c85432d21a8cd254b030c2dd14ce9e9dc0df9d" alt=""
data:image/s3,"s3://crabby-images/d1662/d1662d200d543c8625b66fc56c862fd87b3bd44d" alt=""
注意:如果bundle为nil 就默认为mainBundle,cell的高度是由tableview的rowHeight属性或代理方法决定的,在xib中设置cell的高度是无效的,默认44
6、通过storyboard直接在控制器中自定义cell
在拖动tableViewCell时候tableView的rowHeight会跟随改变,所以我们不要在用代码设置tableView的rowHeight或通过代理方法设置.
data:image/s3,"s3://crabby-images/478c8/478c8be9f83a4a483848b7fc8f227e84173e713e" alt=""
data:image/s3,"s3://crabby-images/b0a50/b0a50dad003d0d9a318e2b4e7884f4403e738114" alt=""
7、自定义分割线
自定义分割线
8、自定义不等高cell
- 纯代码方式:
-
frame:
image.png
-
-
设计思路:
1.在模型中分别新增保存每个控件frame的属性
2.在模型中新增一个cellHeight属性,然后在get方法中根据设置每个控件的frame并赋值给相对于的模型属性,然后计算cell的高度。
3.在cell的 layoutSubViews 方法中 把模型中的保存的每个控件的frame赋值给控件
4.在设置cell高度的 heightForRowAtIndexPath:方法中根据indexPath拿到对应的模型,然后通过getter方法获取cell高度。即是模型中getter方法,为了提高性能,要判断模型中的cellHeight是否有值,没值的话再算。相应的代码如下:
image.png
data:image/s3,"s3://crabby-images/127a2/127a2c1a643d34cc53685c0dd7c51b94312bd43c" alt=""
data:image/s3,"s3://crabby-images/cac44/cac447ef3785243d288ead89e245b911df09bbbd" alt=""
data:image/s3,"s3://crabby-images/4b177/4b177f5a5d9a54e164408b1095ba99dd28351f15" alt=""
- storyboard方式:
- 核心代码
data:image/s3,"s3://crabby-images/a7b31/a7b31502c1a4f2228e5793e8ee75df15b09b1ba0" alt=""
data:image/s3,"s3://crabby-images/a9ff8/a9ff85b0c0ada1bfe8a8b91b32ca3448cc12fe85" alt=""
data:image/s3,"s3://crabby-images/f10c4/f10c47bac8fd0153b17005a8ec5353253a9a2c7b" alt=""
data:image/s3,"s3://crabby-images/cfc6b/cfc6b4e5c998fccdbc17f1f864f9fa666f372b6b" alt=""
data:image/s3,"s3://crabby-images/0b1fa/0b1fa043cbfe6a8cd63b147819d40f3d5540f142" alt=""
注意:
如果tableviewcell是从storyboard或xib加载的,不会调用 initWithStyle: reuseIdentifier:方法,会调用 awakeFromNib方法进行初始化。
9、 tableView的全局和局部刷新
- 全局刷新:
reloadData方法 - 1.局部刷新:
reloadRowsAtIndexPaths: withRowAnimation:这种方法适合于cell的个数不变化的刷新。 - 2.增加cell的刷新:
insertRowsAtIndexPaths: withRowAnimation: - 3.删除cell的刷新:
deleteRowsAtIndexPaths: withRowAnimation:
data:image/s3,"s3://crabby-images/e7609/e7609397a0d743b2fa4ae2b528fca45e137af525" alt=""
data:image/s3,"s3://crabby-images/65b98/65b982f58532e824627d6a37a2c201120bdded11" alt=""
data:image/s3,"s3://crabby-images/87083/87083f7c2eca4a05a3e81555e416ad8b4fcbb6f5" alt=""
刷新会重新调用数据源方法。
10、左滑删除功能
-
左滑删除功能
image.png
-
左滑cell出现多个按钮
image.png
data:image/s3,"s3://crabby-images/7984c/7984c8ffcf1ac5c38659dba0a1e604f4fabc04eb" alt=""
-
批量删除
1.要进入编辑模式:默认情况下左边会出现一排红色的“减号”按钮,点击减号按钮相当于左滑。
self.tableView.editing = yes;
或 [self.tableView setEditing: animation:];
2.设置编辑模式下可以多选:
self.tableView.allowsMultipSelectionDurtingEditing = yes;
data:image/s3,"s3://crabby-images/a0bac/a0bac40ac22b7cad4a2c906da90db5723aa5e878" alt=""
data:image/s3,"s3://crabby-images/20f96/20f96cdde60488a77acc9a5b4ea4f1d81561029f" alt=""
-
自定义批量删除cell
思路:改变cell子控件是否显示不能通过拿到cell来操作,因为从缓存池取cell时候可能出现错乱,要通过模型决定cell子控件界面的显示。
自定义批量删除cell
data:image/s3,"s3://crabby-images/41f52/41f52edb91bfac4e1b8e0981c1e808fcc3ebec13" alt=""
data:image/s3,"s3://crabby-images/8a47a/8a47aaeb53505a04e71d5a8d4b78fd503d6cd1f9" alt=""