不等高cell的tableView界面搭建
一.搭建界面

1.界面分析
分析界面的层次结构,分析界面应该用什么控件来搭建
2.界面层次结构
分析之后,我们可以把这个界面分为四个模块(topView middleView commentView bottomView)
这种复杂的界面,我们一般称为:不等高cell
3.界面搭建方式
分析发现,界面大部分是不能确定的(文字高度,有没有图片,评论)
所以我们采用纯代码的方法来搭建界面
但是复杂的界面我们划分过之后,有些小模块里面的内容是固定的
这些固定的小模块我们可以采用xib来搭建
4.有些模块不确定是否显示,搭建的时候怎么处理?
在创建cell的时候,我们先把所有的模块添加进去,不需要的时候隐藏就行了
5.创建cell的代码写在哪里?
首先要自定义cell ,一般创建cell我们要做缓存处理,所以cell创建一般都要注册
通过类注册的本质是调用cell的initWithStyle:方法
- (instancetype)initWithStyle:(UITableViewCellStyle)style reuseIdentifier:(nullable NSString *)reuseIdentifier
我们只需要在这个方法里面写代码就可以了
注意:调用这个方法,一定要调用super 方法
6.怎么确定通过类注册cell一定会调用initWithStyle:方法
在自定义cell的类里面重写这个方法,通过打印信息可以确定
7.为什么不在initWithFrame方法中创建cell?
initWithFrame方法只有当控件通过init方法或initWithFrame方法创建才会调用
而我们创建cell是通过initWithStyle:方法创建的
8.cell这么多模块,怎么搭建?
一个模块一个模块的搭建
先搭建topView模块(搭建界面,加载数据,处理数据),处理完业务逻辑之后再接着搭建下一个模块
二.topView界面搭建
1.搭建方法 xib搭建
2.用什么控件搭建
头像用ImageView, 昵称和时间还有正文分别用label
3.请求数据
查看接口文档,发送网络请求,解析数据,展示数据
展示数据,要设置cell的frame
4.cell的frame怎么确定?
xib中不能确定cell的frame,所以在xib中cell多大都没关系,但是一定要对子控件进行约束
xib中子控件的大小就是显示出来的实际大小
所以:我们加载xib的时候,要重新设置cell的frame
5.cell的高度怎么确定?
cell的高度需要我们手动来计算
6.cell的高度在哪里计算?
6.1不能再cellForRowAtIndexPath方法中计算(晚了)
6.2也不能在heightForRowAtIndexPath计算cell高度,这个方法调用频率非常高
7.计算cell的高度有哪些要求?
7.1一定要在heightForRowAtIndexPath调用之前,计算cell高度
7.2只需要计算一次
8.在哪里计算cell高度?
当请求数据成功的时候,就计算好cell高度
把cell的高度保存到一个数组中,然后在heightForRowAtIndexPath方法里面返回数组中对应的cell的高度
这种方法的缺点:控制器中代码太多,控制器更加重量级
9.也可以在模型里面计算cell的高度
一般来说,我们要做缓存处理,一般是对模型进行缓存
如果把计算代码放到模型里面,那么缓存数据就比较大,性能不好
还有一种方法:可以利用MVVM框架来计算cell高度
不等高cell的tableView界面搭建的更多相关文章
- 自定义不等高cell—storyBoard或xib自定义不等高cell
1.iOS8之后利用storyBoard或者xib自定义不等高cell: 对比自定义等高cell,需要几个额外的步骤(iOS8开始才支持) 添加子控件和contentView(cell的content ...
- iOS开发——UI进阶篇(三)自定义不等高cell,如何拿到cell的行高,自动计算cell高度,(有配图,无配图)微博案例
一.纯代码自定义不等高cell 废话不多说,直接来看下面这个例子先来看下微博的最终效果 首先创建一个继承UITableViewController的控制器@interface ViewControll ...
- 不等高cell搭建(二)
一.commentView模块搭建 commentView样式分为两种 1.xib搭建界面 1.1 因为评论的样式大体上一样,我们可以用同一个xib来处理 1.2 最热评论 用 ...
- 不等高cell的搭建(一)
一.界面搭建 1.确定开发模式 如果界面是固定的,可以用xib 界面的一些内容不固定,就用纯代码 cell用什么方式去开发(我们采用纯代码和xib结合的方式) 2 ...
- 纯代码自定义不等高cell
数据模型.plist解析这里就不过多赘述. 错误思路之一: 通过在heightForRowAtIndexPath:方法中调用cellForRowAtIndexPath:拿到cell,再拿到cell的子 ...
- iOS之处理不等高TableViewCell的几种方法
课题一:如何计算Cell高度 方案一:直接法(面向对象) 直接法,就是把数据布局到Cell上,然后拿到Cell最底部控件的MaxY值. 第一步:创建Cell并正确设置约束,使文字区域高度能够根据文字内 ...
- 处理不等高TableViewCell
课题一:如何计算Cell高度 方案一:直接法(面向对象) 想知道妹纸爱你有多深?直接去问妹纸本人吧! 嗯!Cell也是一样的,想知道cell到底有多高?直接问Cell本人就好了.直接法,就是把数据布局 ...
- 非等高cell实战(01)-- 实现微博页面
非等高cell实战(01)-- 实现微博页面 学习过UITableView.AutoLayout以及MVC的相关知识,接下来通过一个微博页面实战来整合一下. 首先看一下效果图: 需求分析 此页面为非等 ...
- 非等高cell实战--实现微博页面
代码地址如下:http://www.demodashi.com/demo/11639.html 前言 学习过UITableView.AutoLayout以及MVC的相关知识,接下来通过一个微博页面实战 ...
随机推荐
- Eclipse中用User Library管理jar包
目的:为了更方便的管理jar包,而不是一股脑儿的将引用的jar包全部放在Web App Library下. 管理和配置: 第一步:管理 新建Library并引入项目中 右键项目->Build P ...
- C#winform中ListView的使用
使用ListView模仿Windows系统的资源管理器界面,实现文件(夹)的浏览.重命名.删除及查询等功能,主要功能界面展示如下: 1.MainForm.cs及MainForm.Designer.cs ...
- Ruby--Array
--后面连接其它数组:[ARRAY].concat([OTHER ARRAY]) --排序:sort,进阶:sort_by{|obj| obj.[VALUE]} --随机获取:[ARRAY].samp ...
- SVN使用安装
SVN简介: 为什么要使用SVN? 程序员在编写程序的过程中,每个程序员都会生成很多不同的版本,这就需要程序员有效的管理代码,在需要的时候可以迅速,准确取出相应的版本. Subversion是什么? ...
- perl常用代码
字符串联结和重复操作符 联接: . 重复:x 联接且赋值(类似+=): .=例: $newstring = "potato" . "head"; $ ...
- nginx https
默认情况下ssl模块并未被安装,如果要使用该模块则需要在编译时指定–with-http_ssl_module参数,安装模块依赖于OpenSSL库和一些引用文件,通常这些文件并不在同一个软件包中.通常这 ...
- 使用dnspod进行简单的HTTP dns解析(防劫持)
https://www.dnspod.cn/httpdns/guide https://www.dnspod.cn/misc/D%2B免费版本接口说明.pdf 最简单的get接口去请求dnspod提供 ...
- C++ 字符串操作常见函数
//字符串拷贝,排除指定字符 char *strcpy_exclude_char(char *dst, const int dst_len, const char *src, const char * ...
- php---实现保留小数点后两位
PHP 中的 round() 函数可以实现 round() 函数对浮点数进行四舍五入. round(x,prec) 参数说明x 可选.规定要舍入的数字.prec 可选.规定小数点后的位数. 返回将 x ...
- angularJS自定义指令模板替换
<html> <head> <meta charset="utf-8"/> <title></title> </h ...