不等高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的相关知识,接下来通过一个微博页面实战 ...
随机推荐
- Linux - full name of command
pwd: print working directory cd: change directory ls: list ps: process status su: switch user mv: mo ...
- Open Sourcing Kafka Monitor
https://engineering.linkedin.com/blog/2016/05/open-sourcing-kafka-monitor https://github.com/lin ...
- JAVA内省(Introspector)
什么是Java内省:内省是Java语言对Bean类属性.事件的一种缺省处理方法. Java内省的作用:一般在开发框架时,当需要操作一个JavaBean时,如果一直用反射来操作,显得很麻烦:所以sun公 ...
- docker jenkins
https://segmentfault.com/a/1190000003732967
- Android Studio工具修理集
本文来自http://blog.csdn.net/liuxian13183/ ,引用必须注明出处! 1.Common依赖项目找不到.因为主项目没有引进setting.gradle 2.从Eclipse ...
- 让Qt的无边框窗口支持拖拽、Aero Snap、窗口阴影等特性
环境:Desktop Qt 5.4.1 MSVC2013 32bit 需要的库:dwmapi.lib .user32.lib 需要头文件:<dwmapi.h> .<windowsx. ...
- 【Android开发学习笔记】【第八课】五大布局-下
概念 五大布局上一篇文章已经介绍了 LinearLayout RelativeLayout 这一篇我们介绍剩下的三种布局 FrameLayout 五种布局中最佳单的一种布局.在这个布局在整个界面被当成 ...
- php——n维数组的遍历——递归
<?php /**** ****/function digui($arr){ foreach($arr as $key => $value) { if(is_ar ...
- JS-002-修改元素属性(以按钮示例)
此文以修改 button 元素属性(例如:添加属性.修改属性.修改颜色样式.边框样式等)为简单示例,演示 js 修改 HTML 元素属性的基本方法,敬请参阅.若有不足之处敬请指正,不胜感激! 多不闲述 ...
- Selenium2学习-015-WebUI自动化实战实例-013-通过 URL 关闭多余的已开浏览器窗口
在日常的 WebUI 自动化测试脚本执行的过程中,经常会打开不同的网页,进行相应的操作,此时可能会打开很多的网页,当打开的网页过多时,无效的网页资源对运行脚本的机器造成了过多无效的资源浪费,因而在日常 ...