Swift - UITableView的简单实现
记录整理下tableView的实现,方便日后查看。分为三部分进行记录学习:
1.使用UITableViewCell实现一个简单的tableView
2.使用自定义cell实现带索引列表的tableView
3.与UISearchBar的简单结合使用
- 以下是Demo演示
- 以下是代码实现
使用UITableViewCell实现一个简单的tableView
//
// TableView1.swift
// UITableView
//
// Created by StYiWe on 2020/9/14.
// Copyright © 2020 stYiwe. All rights reserved.
//
import UIKit
class TableView1: UIViewController, UITableViewDelegate, UITableViewDataSource {
//tableView
var tableView = UITableView()
//数据
var dataList: NSMutableArray = []
override func viewDidLoad() {
super.viewDidLoad()
self.view.backgroundColor = .white
self.title = "使用系统cell"
//右上角编辑按钮
self.navigationItem.rightBarButtonItem = UIBarButtonItem.init(barButtonSystemItem: .edit, target: self, action: #selector(editAction))
//数据
dataList = NSMutableArray.init(array: ["🐰", "秃子", "鹰酱", "毛熊", "棒子", "脚盆鸡", "高卢鸡", "狗大户", "🐫", "沙某", "河马"])
//UI
createTableViewUI()
}
//MARK: - 实例化tableView
func createTableViewUI() {
tableView = UITableView.init(frame: UIScreen.main.bounds, style: .plain)
tableView.delegate = self
tableView.dataSource = self
//注册cell
tableView.register(UITableViewCell.self, forCellReuseIdentifier: "cellID")
//去除分割线
// tableView.separatorStyle = .none
//去掉多余的分割线
tableView.tableFooterView = UIView()
self.view.addSubview(tableView)
}
//MARK: - 编辑
@objc func editAction() {
//设置可编辑
tableView.setEditing(true, animated: true)
//完成按钮
self.navigationItem.rightBarButtonItem = UIBarButtonItem.init(barButtonSystemItem: .done, target: self, action: #selector(doneAction))
}
//MARK: - 编辑完成
@objc func doneAction() {
//设置不可编辑
tableView.setEditing(false, animated: true)
//右上角编辑按钮
self.navigationItem.rightBarButtonItem = UIBarButtonItem.init(barButtonSystemItem: .edit, target: self, action: #selector(editAction))
}
//MARK: - 返回多少行
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return dataList.count
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "cellID", for: indexPath)
cell.textLabel?.text = dataList[indexPath.row] as? String
return cell
}
//MARK: - 行高
func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
return 60
}
//MARK: - 点击cell
func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
print(dataList[indexPath.row])
}
//MARK: - 使cell的分割线与屏幕两端对齐
func tableView(_ tableView: UITableView, willDisplay cell: UITableViewCell, forRowAt indexPath: IndexPath) {
if cell.responds(to: #selector(setter: UITableViewCell.separatorInset)) {
cell.separatorInset = .zero
}
if cell.responds(to: #selector(setter: UITableViewCell.layoutMargins)) {
cell.layoutMargins = .zero
}
}
//MARK: - 设置编辑样式
func tableView(_ tableView: UITableView, editingStyleForRowAt indexPath: IndexPath) -> UITableViewCell.EditingStyle {
//编辑的时候返回带有选择按钮的样式
// return UITableViewCell.EditingStyle(rawValue: UITableViewCell.EditingStyle.RawValue(UInt8(UITableViewCell.EditingStyle.insert.rawValue) | UInt8(UITableViewCell.EditingStyle.delete.rawValue)))!
//添加
// return .insert
//删除
return .delete
}
//MARK: - 删除单元格
func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCell.EditingStyle, forRowAt indexPath: IndexPath) {
if editingStyle == .delete {
print("要删除\(dataList[indexPath.row])")
//提示
let alertC = UIAlertController.init(title: "温馨提示", message: "确定要删除\(dataList[indexPath.row])?", preferredStyle: .alert)
alertC.addAction(UIAlertAction.init(title: "确定", style: .destructive, handler: { (UIAlertAction) in
self.dataList.removeObject(at: indexPath.row)
tableView.reloadData()
}))
alertC.addAction(UIAlertAction.init(title: "取消", style: .cancel, handler: nil))
present(alertC, animated: true, completion: nil)
}
if editingStyle == .insert {
print("增加")
}
}
//MARK: - 允许排序
func tableView(_ tableView: UITableView, canMoveRowAt indexPath: IndexPath) -> Bool {
return true
}
//MARK: - 排序
func tableView(_ tableView: UITableView, moveRowAt sourceIndexPath: IndexPath, to destinationIndexPath: IndexPath) {
tableView.moveRow(at: sourceIndexPath, to: destinationIndexPath)
dataList.exchangeObject(at: sourceIndexPath.row, withObjectAt: destinationIndexPath.row)
tableView.reloadData()
}
}
使用自定义cell实现带索引列表的tableView
//
// TableView2.swift
// UITableView
//
// Created by StYiWe on 2020/9/14.
// Copyright © 2020 stYiwe. All rights reserved.
//
import UIKit
//cell Identifier
let cellID = "cellID"
class TableView2: UIViewController, UITableViewDelegate, UITableViewDataSource {
//tableView
var tableView = UITableView()
//数据
var dataList = [String]()
//处理后的数据(根据首字母进行分组)
var resultDict = [String : [String]]()
//组头标题数组
var sectionTitles = [String]()
override func viewDidLoad() {
super.viewDidLoad()
self.title = "带索引的UITableView"
self.view.backgroundColor = .white
//原始数据
dataList = ["🐰", "秃子", "鹰酱", "毛熊", "Cat", "棒子", "脚盆鸡", "高卢鸡", "狗大户", "🐫", "沙某", "河马", "Big Dog", "Apple"]
//数据处理
createResultDict()
//tableVIew
tableView = UITableView.init(frame: UIScreen.main.bounds, style: .plain)
tableView.delegate = self
tableView.dataSource = self
//去掉多余的分割线
tableView.tableFooterView = UIView()
//注册cell
tableView.register(UINib(nibName: "TableView2Cell", bundle: nil), forCellReuseIdentifier: cellID)
self.view.addSubview(tableView)
}
//MARK: - 数据处理,根据首字母进行分组
/**
```
数据**处理**,根据`首字母`进行分组
```
*/
func createResultDict() {
for str in dataList {
//获得首字母
let firstLetterIndex = str.index(str.startIndex, offsetBy: 1)
var firstLetter = String(str[..<firstLetterIndex])
//转成大写字母
firstLetter = firstletterFromString(str: firstLetter)
if var values = resultDict[firstLetter] {
values.append(str)
resultDict[firstLetter] = values
} else {
resultDict[firstLetter] = [str]
}
//组头标题
sectionTitles = [String](resultDict.keys)
//排序
sectionTitles = sectionTitles.sorted(by: {$0 < $1})
}
}
//MARK: - 将中文转成大写字母
func firstletterFromString(str: String) -> String {
//转变成可变字符串
let mutableStr = NSMutableString.init(string: str)
//将中文转变成带声调的拼音
CFStringTransform(mutableStr as CFMutableString, nil, kCFStringTransformToLatin, false)
//去掉声调
let pyStr = mutableStr.folding(options: .diacriticInsensitive, locale: .current)
//将拼音换成大写
let PYStr = pyStr.uppercased()
//截取大写首字母
let index = PYStr.index(PYStr.startIndex, offsetBy: 1)
let firstStr = PYStr[..<index]
//判断首字母是否为大写
let uppercaseLetter = "^[A-Z]$"
let predicateLetter = NSPredicate.init(format: "SELF MATCHES %@", uppercaseLetter)
return String(predicateLetter.evaluate(with: firstStr) ? firstStr : "#")
}
//MARK: - 返回多少组
func numberOfSections(in tableView: UITableView) -> Int {
return sectionTitles.count
}
//MARK: - 每组多少行
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
let key = sectionTitles[section]
guard let values = resultDict[key] else {
return 0
}
return values.count
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: cellID, for: indexPath) as! TableView2Cell
let key = sectionTitles[indexPath.section]
let values = resultDict[key]
cell.titleLabel.text = values?[indexPath.row]
return cell
}
//MARK: - 行高
func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
return 60
}
//MARK: - section标题
func tableView(_ tableView: UITableView, titleForHeaderInSection section: Int) -> String? {
return sectionTitles[section]
}
//MARK: - 索引列表
func sectionIndexTitles(for tableView: UITableView) -> [String]? {
return sectionTitles
}
}
与UISearchBar的简单结合使用
//
// TableView3.swift
// UITableView
//
// Created by StYiWe on 2020/9/15.
// Copyright © 2020 stYiwe. All rights reserved.
//
import UIKit
class TableView3: UIViewController, UITableViewDelegate, UITableViewDataSource, UISearchBarDelegate {
//searchBar
var searchBar : UISearchBar!
//tableView
var tableView : UITableView!
//数据
var dataList = ["🐰", "秃子", "鹰酱", "毛熊", "Cat", "棒子", "脚盆鸡", "高卢鸡", "狗大户", "🐫", "沙某", "河马", "Big Dog", "Apple"]
//搜索数据
var searchDataList: [String] = []
override func viewDidLoad() {
super.viewDidLoad()
self.title = "与UISearchBar一起使用"
self.view.backgroundColor = .white
//搜索数据默认加载全部
searchDataList = dataList
//UI
creatUI()
}
func creatUI() {
//tableView
tableView = UITableView.init(frame: UIScreen.main.bounds, style: .plain)
tableView.delegate = self
tableView.dataSource = self
tableView.tableFooterView = UIView()
//注册cell
tableView.register(UITableViewCell.self, forCellReuseIdentifier: "cellID")
self.view.addSubview(tableView)
//searchBar
searchBar = UISearchBar.init(frame: CGRect(x: 0, y: 0, width: UIScreen.main.bounds.size.width, height: 60))
//显示取消按钮
searchBar.showsCancelButton = true
searchBar.delegate = self
tableView.tableHeaderView = searchBar
}
//MARK: - 取消搜索
func searchBarCancelButtonClicked(_ searchBar: UISearchBar) {
self.view.endEditing(true)
searchBar.text = ""
searchDataList = dataList
tableView.reloadData()
}
//MARK: - 搜索代理,每次改变搜索内容都会调用
func searchBar(_ searchBar: UISearchBar, textDidChange searchText: String) {
print("搜索内容:\(searchText)")
//没有搜索内容时显示全部数据
if searchText == "" {
searchDataList = dataList
} else {
//获取搜索栏文字,筛选后更新列表
let text = searchText.trimmingCharacters(in: .whitespaces)
//获取符合的数据
searchFilter(text: text)
}
tableView.reloadData()
}
//MARK: - 添加一个筛选器方法:使用Swift数组系统filter方法,返回一个符合条件的新数组
func searchFilter(text: String) {
searchDataList = dataList.filter({ (str) -> Bool in
return str.localizedCaseInsensitiveContains(text)
})
}
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return searchDataList.count
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "cellID", for: indexPath)
cell.textLabel?.text = searchDataList[indexPath.row]
return cell
}
}
附上Demo
网友评论