Swift - 实现带有搜索框的导航栏(将UISearchController集成到Navigation上)
作者:hangge | 2019-01-29 08:10
iOS 11 引入了一个新特性,只需要将 UISearchController 赋值给 navigationItem,就可以实现将 UISearchController 集成到 Navigation 上。下面通过样例进行演示。

(2)运行效果如下:

1,效果图
(1)默认情况下导航栏上是看不到搜索框的。
(2)当下拉页面时,搜索框自动出现。而向上滑动页面,搜索框又会自动隐藏。
(3)在搜索框中输入文字,可对表格显示的内容进行过滤。

2,样例代码
import UIKit
class ViewController: UIViewController {
// 搜索控制器
var searchController: UISearchController!
//展示列表
var tableView: UITableView!
//原始数据集
let schoolArray = ["清华大学","北京大学","中国人民大学","北京交通大学","北京工业大学",
"北京航空航天大学","北京理工大学","北京科技大学","中国政法大学",
"中央财经大学","华北电力大学","北京体育大学","上海外国语大学","复旦大学",
"华东师范大学","上海大学","河北工业大学"]
//搜索过滤后的结果集
var searchArray:[String] = [String](){
didSet {self.tableView.reloadData()}
}
override func viewDidLoad() {
super.viewDidLoad()
// 初始化搜索控制器
self.searchController = UISearchController(searchResultsController: nil)
self.searchController.searchResultsUpdater = self
self.searchController.dimsBackgroundDuringPresentation = false
// 将搜索控制器集成到导航栏上
navigationItem.searchController = self.searchController
//创建表视图
let tableViewFrame = CGRect(x: 0, y: 20, width: self.view.frame.width,
height: self.view.frame.height-20)
self.tableView = UITableView(frame: tableViewFrame, style:.plain)
self.tableView!.delegate = self
self.tableView!.dataSource = self
//创建一个重用的单元格
self.tableView!.register(UITableViewCell.self,
forCellReuseIdentifier: "MyCell")
self.view.addSubview(self.tableView!)
}
}
extension ViewController: UISearchResultsUpdating {
//实时进行搜索
func updateSearchResults(for searchController: UISearchController) {
self.searchArray = self.schoolArray.filter { (school) -> Bool in
return school.contains(searchController.searchBar.text!)
}
}
}
extension ViewController: UITableViewDataSource, UITableViewDelegate
{
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
if self.searchController.isActive {
return self.searchArray.count
} else {
return self.schoolArray.count
}
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath)
-> UITableViewCell {
//为了提供表格显示性能,已创建完成的单元需重复使用
let identify:String = "MyCell"
//同一形式的单元格重复使用,在声明时已注册
let cell = tableView.dequeueReusableCell(withIdentifier: identify,
for: indexPath)
if self.searchController.isActive {
cell.textLabel?.text = self.searchArray[indexPath.row]
return cell
} else {
cell.textLabel?.text = self.schoolArray[indexPath.row]
return cell
}
}
}
附:让搜索栏一直显示
(1)上面样例中,搜索栏会随着页面的滑动自动显示或者隐藏,如果想要它一直显示,可以将 navigationItem 的 hidesSearchBarWhenScrolling 属性设置 false 即可。
// 将搜索控制器集成到导航栏上 navigationItem.searchController = self.searchController // 不隐藏导航栏的搜索框 navigationItem.hidesSearchBarWhenScrolling = false
(2)运行效果如下:

全部评论(0)