- UITableVIew的属性
- UITableVIew继承自UIScrollView
- tableView上显示的内容,一般不是通过添加子视图去显示,而是通过cell去显示数据
self.tableView = UITableView.init(frame: self.view.bounds)
// 2.添加到界面上
self.view.addSubview(self.tableView!)
// 3.设置代理(显示数据的核心在协议里面实现,所以要设置代理)
// 专门负责数据的显示
self.tableView?.dataSource = self
// 4.设置tabView上cell的高度
self.tableView?.rowHeight = 200
- 因为设置了代理所以需要实现协议方法
下面我们来写协议方法
注意了协议里面有两个方法必须实现
extension ViewController: UITableViewDataSource {
// 一个tableView上可以有多个分组(section),每一组又可以有多行(多个cell);默认情况下tableView只有一个分组
// 1.设置每一个分组的行数(cell的个数)
// 有多少个分组调用多少次(开始的时候)
// 参数1: 委托
// 参数2: 当前组的下标(当前是第几组)(下标0开始)
// 返回值:设置的cell的个数
func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return 10
}
// 2.创建每一行的cell
// 通过上边的方法设置的行数,就是当前这个方法每次调用的次数
// 要做的事情:a.确定每一行cell的风格 b.确定cell上显示的内容
// 参数1: 委托
// 参数2: cell的位置(通过组数和行数来确定)(比如说:在第几组第几行) section -> 组 , row -> 行
// 返回值:创建的cell
// UITableViewCell只能在tableView上作为cell显示内容
func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
// 1.去复用池中查看是否有可以复用的cell;如果有就直接返回可以复用的cell,没有就返回nil
// 当cell在滚动的时候,滚出了界面以外,那这个cell就会被添加到复用池中
// Identifier的作用是区分复用池中不同的cell
var cell = tableView.dequeueReusableCellWithIdentifier("cell")
// 2.判断是否找到可以复用的cell
if cell == nil {
// 如果没有找到可以复用的cell,就去创建新的cell
// 最多创建一屏的cell的个数加1或者加2
cell = UITableViewCell.init(style: .Subtitle, reuseIdentifier: "cell")
}else{
print("复用的cell")
}
// 3.刷新数据(给cell上显示的内容重新赋值)(如果复用池中有cell就直接拿过来用,但是要刷新数据)
cell?.textLabel?.text = "第\(indexPath.section)组,第\(indexPath.row)行"
// 4.返回cell
return cell!
}
}