时间:2021-12-03 09:26:23 | 栏目:iOS代码 | 点击:次
本文详细介绍了表视图的用法。具体如下:
概述
表视图组成
表视图是iOS开发中最重要的视图,它以列表的形式展示数据。表视图又一下部分组成:
表头视图:表视图最上边的视图
表脚视图:表视图最下边的视图
单元格(cell):表视图中每一行的视图
节(section):由多个单元格组成,应用于分组列表
节头
节脚
表视图的相关类
UITableView继承自UIScrollView,且有两个协议:UITableViewDelegate和UITableViewDataSource。此外UITableViewCell类时单元格类,UITableViewController类时UITableView的控制器,UITableViewHeaderFooterView用于为节头和节脚提供视图。
表视图分类
单元格的组成和样式
单元格由图标、主标题、副标题、扩展视图组成,可以根据需要进行选择,其中内置的扩展视图在枚举类型
Swift枚举成员 | Objective-C枚举成员 | 说明 |
---|---|---|
none | ITableViewCellAccessoryNone | 没有扩展图标 |
disclosureIndicator | UITableViewCellAccessoryDisclosureIndicator | 扩展指示器,为箭头+问号 |
detailDisclosureButton | UITableViewCellAccessoryDetailDisclosureButton | 细节展示图,为问号 |
checkmark | UITableViewCellAccessoryCheckmark | 选中标志,图标为勾 |
detailButton | UITableViewCellAccessoryDetailButton | 细节详情展示,图标为问号 |
内置的单元格样式在枚举类型UITableViewCellStyle中定义:
Swift枚举成员 | Objective-C枚举成员 | 说明 |
---|---|---|
default | UITableViewCellStyleDefault | 默认样式 |
subtitle | UITableViewCellStyleSubtitle | 有图标、主标题、副标题、副标题在主标题的下面 |
value1 | UITableViewCellStyleValue1 | 有主标题、副标题,主标题左对齐、副标题右对齐,可以有图标 |
2alue3 | UITableViewCellStyleValue2 | 有主标题、副标题,主标题和副标题居中对齐,无图标 |
数据源协议与委托协议
UITableViewDataSource
数据源协议主要为表视图提供数据,主要方法如下
方法 | 返回类型 | 说明 |
---|---|---|
func tableView(UITableView, cellForRowAt: IndexPath) | UITableViewCell | 为表视图单元格提供数据,必须实现 |
tableView(UITableView, numberOfRowsInSection: Int) | Int | 返回某个节中的行数,必须实现 |
tableView(UITableView, titleForHeaderInSection: Int) | String | 返回节头的标题 |
tableView(UITableView, titleForFooterInSection: Int) | String | 返回节脚的标题 |
numberOfSections(in: UITableView) | Int | 返回节的个数 |
sectionIndexTitles(for: UITableView) | [String]? | 返回表示图节索引标题 |
UITableViewDelegate
委托协议主要主要用来设定表视图中节头和节脚的标题,以及一些动作事件,主要方法如下
方法 | 返回类型 | 说明 |
---|---|---|
tableView(UITableView, didSelectRowAt: IndexPath) | 单元格响应事件 | |
tableView(UITableView, accessoryButtonTappedForRowWith: IndexPath) | 扩展视图响应事件 |
简单表视图
UIViewController根视图控制器实现表视图
步骤
实现
// // ViewController.swift // TableViewDemo // // Created by Michael on 2016/10/26. // Copyright © 2016年 Michael. All rights reserved. // import UIKit class ViewController: UIViewController,UITableViewDataSource,UITableViewDelegate { //全部数据 var listItems: NSArray! override func viewDidLoad() { super.viewDidLoad() //读取资源文件数据 let listPath = Bundle.main.path(forResource: "team", ofType: "plist") self.listItems = NSArray(contentsOfFile: listPath!) } override func didReceiveMemoryWarning() { super.didReceiveMemoryWarning() // Dispose of any resources that can be recreated. } //返回列表每行的视图 func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { //根据Identifier找到Cell let cell = tableView.dequeueReusableCell(withIdentifier: "CustomId", for: indexPath) let row = indexPath.row let rowDict = self.listItems[row] as! NSDictionary cell.textLabel?.text = rowDict["name"] as? String cell.detailTextLabel?.text = "123" let imagePath = String(format: "%@.png", rowDict["image"] as! String) cell.imageView?.image = UIImage(named: imagePath) cell.accessoryType = UITableViewCellAccessoryType.disclosureIndicator return cell } //返回条目数目 func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { return self.listItems.count } //响应条目点击事件 func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) { print("点击事件") } }
示例图
none模式
disclosureIndicator
UITableViewController根视图控制器实现表视图
步骤
实现
import UIKit class ViewController: UITableViewController { //全部数据 var listItems: NSArray! override func viewDidLoad() { super.viewDidLoad() //读取资源文件数据 let listPath = Bundle.main.path(forResource: "team", ofType: "plist") self.listItems = NSArray(contentsOfFile: listPath!) } override func didReceiveMemoryWarning() { super.didReceiveMemoryWarning() // Dispose of any resources that can be recreated. } //返回列表每行的视图 func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { let cell = tableView.dequeueReusableCell(withIdentifier: "CustomId", for: indexPath) let row = indexPath.row let rowDict = self.listItems[row] as! NSDictionary cell.textLabel?.text = rowDict["name"] as? String cell.detailTextLabel?.text = "123" let imagePath = String(format: "%@.png", rowDict["image"] as! String) cell.imageView?.image = UIImage(named: imagePath) cell.accessoryType = UITableViewCellAccessoryType.disclosureIndicator return cell } //返回条目数目 func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { return self.listItems.count } //响应条目点击事件 func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) { print("点击事件") } }
示例图
detailButton模式
checkmark模式
自定义单元格
步骤
实现
CustomCell类
// // CustomCell.swift // CustomCell // // Created by Michael on 2016/10/25. // Copyright © 2016年 Michael. All rights reserved. // import UIKit class CustomCell: UITableViewCell { @IBOutlet weak var mImage: UIImageView! @IBOutlet weak var mLabel: UILabel! override func awakeFromNib() { super.awakeFromNib() // Initialization code } override func setSelected(_ selected: Bool, animated: Bool) { super.setSelected(selected, animated: animated) // Configure the view for the selected state } }
ViewController类
// // ViewController.swift // SimpleTableView // // Created by Michael on 2016/10/24. // Copyright © 2016年 Michael. All rights reserved. // import UIKit class ViewController: UITableViewController { var listItems: NSArray! override func viewDidLoad() { super.viewDidLoad() // Do any additional setup after loading the view, typically from a nib. let listPath = Bundle.main.path(forResource: "team", ofType: "plist") self.listItems = NSArray(contentsOfFile: listPath!) } override func didReceiveMemoryWarning() { super.didReceiveMemoryWarning() // Dispose of any resources that can be recreated. } override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { return self.listItems.count } override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { //找到自定义单元格 let cell:CustomCell! = tableView.dequeueReusableCell(withIdentifier: "CustomCellId", for: indexPath) as? CustomCell //let cell = UITableViewCell(style: .value1, reuseIdentifier: "CellIdentifier") let row = indexPath.row let rowDict = self.listItems[row] as! NSDictionary //设置控件属性 cell.mLabel.text = rowDict["name"] as? String let imagePath = String(format: "%@.png", rowDict["image"] as! String) cell.mImage.image = UIImage(named: imagePath) cell.accessoryType = .disclosureIndicator return cell } }
示例图