UITableView
UITableView 在Ios中大量使用,我们对UITableview中的有关知识进行整理
UITAbleView是表视图控制器
1 UITableView初始化
2UITableview实现代理
3UITableView必须实现的方法(UITableviewdatasource)
3.1一个组里有多少cell
3.2 UITableviewcell的内容
4
UIcollectionView
UIcollectionView是集合视图
1 UIcollectionFlowLayout的初始化
2 UIcollectionView 的初始化
3 UIcollectionView实现代理
4 两个必须实现的方法
//关于UITableViewCell 和UICollectionViewCell的介绍
UITableview全面解析
在iOS开发中UITableView可以说是使用最广泛的控件,我们平时使用的软件中到处都可以看到它的影子,类似于微信、QQ、新浪微博等软件基本上随处都是UITableView。当然它的广泛使用自然离不开它强大的功能,今天这篇文章将针对UITableView重点展开讨论。今天的主要内容包括:
UITableView有两种风格:UITableViewStylePlain和UITableViewStyleGrouped。这两者操作起来其实并没有本质区别,只是后者按分组样式显示前者按照普通样式显示而已。大家先看一下两者的应用
1>分组样式
2>不分组样式
大家可以看到在UITableView中数据只有行的概念,并没有列的概念,因为在手机操作系统中显示多列是不利于操作的。UITableView中每行数据都是一个UITableViewCell,在这个控件中为了显示更多的信息,iOS已经在其内部设置好了多个子控件以供开发者使用。如果我们查看UITableViewCell的声明文件可以发现在内部有一个UIView控件(contentView,作为其他元素的父控件)、两个UILable控件(textLabel、detailTextLabel)、一个UIImage控件(imageView),分别用于容器、显示内容、详情和图片。使用效果类似于微信、QQ信息列表:
当然,这些子控件并不一定要全部使用,具体操作时可以通过UITableViewCellStyle进行设置,具体每个枚举表示的意思已经在代码中进行了注释:
typedef NS_ENUM(NSInteger, UITableViewCellStyle) {
UITableViewCellStyleDefault, // 左侧显示textLabel(不显示detailTextLabel),imageView可选(显示在最左边)
UITableViewCellStyleValue1, // 左侧显示textLabel,右侧显示detailTextLabel(默认蓝色),imageView(显示在最左边)
UITableViewCellStyleValue2, // 左侧依次显示textLable(默认蓝色)和detailTextLabel,imageView可选(显示在最左边)
UITableViewCellStyleSubtitle // 左上方显示textLabel,左下方显示detailTextLabel(默认灰色),imageView可选(显示在最左边)
};
数据源
由于ios是遵循MVC模式设计的,很多操作都是通过代理和外界沟通的,但对于数据源控件除了代理还有一个数据源属性,通过它和外界进行数据交互,对于UITableView设置完dateSource后需要实现UITableViewDataSource协议,在这个协议中定义了多种数据操作方法,下面通过创建一个简单的联系人管理进行演示
运行可以看到如下效果
大家在使用iPhone通信录是会发现右侧可以按字母检索,使用起来很方便,其实这个功能使用UITableView实现很简单,只要是实现数据源协议的一个方法,构建一个分组标题的数组即可实现,数组元素的内容和组标题内容未必完全一致,UITableView是按照数组元素的索引和每组数据索引顺序来定位的不是按内容查找
效果如下
需要注意的是上面几个重点方法的执行顺序,请看下图
值得指出的是生成单元格的方法并不是一次全部调用,而是只会产生当前显示在界面上的单元格,当用户滚动操作时,再显示其他单元格
注意:随着我们的应用越来越复杂,可能经常需要调试程序,在ios中默认情况下不能定位到错误代码行,我们可以通过如下设置让程序定位到出错代码行:Show the Breakpoint navigator - AddException breakpoint
代理
上面我们已经看到通讯录得简单实现,但是我们发现单元格高度,分组标题高度以及尾部说明的高度都需要调整,此时就需要使用代理方法。UITalbleView代理方法有很多,例如监听单元格显示周期,监听单元格选择编辑操作,设置是否高亮显示单元格,设置行高等
1设置高度
2监听点击
在iOS 中点击某个联系人就可以呼叫这个联系人,这时就需要监听点击操作,这里就不演示呼叫联系人操作了,我们演示一下修改人员信息的操作
在上面的代码中我们通过修改模型来改变UI显示,这种方式是经典的MVC应用,在后面的代码中会经常。当然UI的刷新使用了UITableView的reloadData方法,该方法会重新调用数据源方法,包括计算分组,计算每个分组的行数,生成单元格等刷新整个UITableView。当然这种方式在实际开发中是不可取的,我们不能因为修改了一个人的信息就刷新这个UITableView,此时我们需要采用局部刷新,局部刷新使用起来很简单,只需要调用UITableView的另一个方法:
性能优化
前面已经说过UITableView中的单元格cell是在显示到用户可是区域后创建的,那么如果用户往下滚动就会继续创建显示在屏幕上的单元格,如果用户向下滚动返回到查看过的内容是同样会重新创建之前已经创建过的单元格。如此一来即使UITableView的内容不是太多。如果用户反复的上下滚动,内存也会瞬间飙升,更何况很多时候UITalbleView的内容是很多的(例如微博展示列表,基本向下滚动是没有底限的)
前面一节中我们曾经提到过如何优化UIScrollView,当时就是利用有限的UIImageView动态切换其内容来尽可能减少资源占用。同样的,在UITableView中也可以采用类似的方式,只是这时我们不是在滚动到指定位置后更改滚动的位置而是要将当前没有显示的Cell重新显示在将要显示的Cell的位置然后更新其内容。原因就是UITableView中的cell结构布局可能是不同的,通过重新定位是不可取的,而是需要重用已经不在界面显示的已创建过的Cell。
当然,听起来这么做比较复杂,其实实现起来很简单,因为UITableView已经为我们实现了这中机制。在UITableView内部有一个缓存池,初始化时使用initWithStyle:(UITableViewCellStyle) reuseIdentifier:(NSString*)方法指定一个可重用标识,就可以将这个cell放到缓存池。然后在使用时使用指定的标识去缓存池中取得对应的cell然后修改cell内容即可
UIScrollView
UIScrollView 是滑动视图
UIScrollView的初始化(如果是从xib或者故事板拖拽的不用初始化)
//属性
contentSize // UIScrollView内容大小的设置 (这个是非常重要的)
pagingEnabled //翻页属性
[_scrollView addSubview:imageView];//把内容视图直接添加即可