- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的问题是,当我尝试过滤它时,我已经在 Swift 3 中实现了 UISearchController
它是很容易过滤的简单数组,但我的情况有点不同,我有一个数组,我从 中获取所有数据>SQLite 数据库
在类中,因此它是类的数组
managerControlClassArray
包含类数组的所有内容。
我想过滤 updateSearchResults
委托(delegate)方法中的内容,但这确实很困难并且卡住了,我做了很多研究,在没有得到我想要的查询后,我发现 StackOverflow 非常有用,如果有人帮助的话,我会质疑它我,我将不胜感激。
一些代码逻辑:
manager = ModelManager.getInstance().getAllManager()
// I get all the objects using singleton
//manager class has following data
id, title, designation, salary
//In TableView i want to display data by using that
let managerVar = manager[indexPath.row]
cell.textLabel.text = managerVar.title
编辑:
MasterTableViewController.swift
import UIKit
class MasterTableViewController: UITableViewController, UISplitViewControllerDelegate, UISearchResultsUpdating {
var array: NSMutableArray! = NSMutableArray()
var managerArray = [foodManager]()
var filteredmanagerArray = [foodManager]()
var searchController = UISearchController(searchResultsController: nil)
override func viewDidLoad() {
super.viewDidLoad()
// Set the AppTitle using Config File
self.title = GL_Appname
managerArray = ModelManager.getInstance().getAllManagers()
filteredmanagerArray = managerArray
//copyTitleArrayForSearch()
self.tableView.reloadData()
self.splitViewController!.delegate = self;
self.splitViewController!.preferredDisplayMode = UISplitViewControllerDisplayMode.allVisible
//Seach Result Controller
self.searchController.searchResultsUpdater = self
self.searchController.dimsBackgroundDuringPresentation = false
self.searchController.definesPresentationContext = true
self.searchController.searchBar.sizeToFit()
self.tableView.tableHeaderView = self.searchController.searchBar
}
/* func copyTitleArrayForSearch(){
for i in 0..<managerArray.count{
let fd = managerArray[i]
//titleArray.append(fd.title)
}
} */
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
// MARK: - Table view data source
override func numberOfSections(in tableView: UITableView) -> Int {
return 1
}
override func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat{
return 60
}
override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
if searchController.isActive{
return filteredmanagerArray.count
}
else{
return managerArray.count
}
}
override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath)
cell.textLabel?.adjustsFontSizeToFitWidth = true
cell.textLabel?.lineBreakMode = NSLineBreakMode.byWordWrapping
cell.textLabel?.numberOfLines = 3
cell.textLabel?.textColor = UIColor.black
cell.textLabel?.font = UIFont(name: "ChalkboardSE-Light", size: 14.0)
if searchController.isActive {
let fra = filteredmanagerArray[indexPath.row]
cell.textLabel?.text = fra.title.uppercased()
}
else{
let fd = managerArray[indexPath.row]
cell.textLabel?.text = fd.title.uppercased()
}
return cell
}
func updateSearchResults(for searchController: UISearchController) {
self.tableView.reloadData()
self.filteredRecipeArray.removeAll(keepingCapacity: false)
let searchPredicate = NSPredicate(format: "SELF CONTAINS[c] %@", searchController.searchBar.text!)
let array = (self.filteredRecipeArray as NSArray).filtered(using: searchPredicate)
self.filteredRecipeArray = array as! [foodRecipe]
self.tableView.reloadData()
}
override func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
print("DidSelect index Path: \(indexPath.row)")
//print("Filtered Manager Index: \(filteredmanagerArray[indexPath.row]))")
self.performSegue(withIdentifier: "showDetail", sender: self)
}
// MARK: - Navigation
// In a storyboard-based application, you will often want to do a little preparation before navigation
override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
if segue.identifier == "showDetail" {
let index = self.tableView.indexPathForSelectedRow! as IndexPath
let nav = segue.destination as! UINavigationController
let vc = nav.viewControllers[0] as! DetailViewController
if searchController.isActive {
print("Manager Array Index: \(managerArray[index.row])")
//var currentFilteredIndex = filteredmanagerArray[(indexPath as NSIndexPath).row]
print("Filtered Manager Array Index: \(filteredmanagerArray[index.row])"
}
else{
vc.selectedmanagerArray = [managerArray[index.row]]
}
//vc.titleText = self.array.object(at: (index as NSIndexPath).row) as! String
self.tableView.deselectRow(at: index, animated: true)
}
}
// MARK: - UISplitViewControllerDelegate
func splitViewController(_ splitViewController: UISplitViewController, collapseSecondary secondaryViewController: UIViewController, onto primaryViewController: UIViewController) -> Bool {
return true
}
}
Manager.swift
class Manager: NSObject{
var id: String = String()
var title: String = String()
var ManagerDesignation: String = String()
}
谢谢。
再见。
最佳答案
我们可以只使用 Swift 内置的 filter
方法吗?
func updateSearchResults(for searchController: UISearchController) {
self.tableView.reloadData()
self.filteredRecipeArray.removeAll(keepingCapacity: false)
guard let searchText = searchController.searchBar.text else {
return
}
let array = managerArray.filter {
return $0.id.range(of: searchText) != nil ||
$0.title .range(of: searchText) != nil ||
$0.ManagerDesignation.range(of: searchText) != nil
}
self.filteredRecipeArray = array
self.tableView.reloadData()
}
编辑
更新了最新 Swift 3 语法的答案
关于ios - UISearchController更新搜索结果问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41270362/
自动呈现 UISearchController 和自己呈现搜索 Controller 的行为不同。 @implementation MyViewComtroller // click search b
这就是我如何设置我的 UIsearchController private func setupSearchController() { let searchResultsController
我在导航项上使用 UISearchController(导航栏已设置为使用 barTintColor 和 twinColor)。当搜索 Controller 关闭(点击搜索栏的取消按钮)时,后退按钮的
我正在尝试创建与 iOS 8 中的联系人应用程序类似的体验。其主要组件是: 保持搜索栏固定在导航栏下方 在展示时将搜索栏附加到 View 顶部(标准功能)。 然而,这说起来容易做起来难。在与 tabl
当我将 UISearchController 的搜索栏中的占位符文本更新为比搜索栏更宽的内容时,搜索图标会发生这种情况: 我通过在 viewDidLoad 中调用以下方法添加了 UISearchCon
我在学习 UISearchController通过关注 this教程。然而,UISearchBar未显示。这是我的代码: let searchController = UISearchControll
我正在使用 UISearchController 在我的表格 View 中搜索数据。我没有使用 TableView Controller 。我想在搜索栏处于事件状态时隐藏导航栏,因此我将 self.s
在我的项目中,我使用了 UITableViewController带有内部 UISearchController过滤我的 tableView 中的数据. 我过滤数据没有问题,但我需要确定我的 tabl
我目前正在将 iPad 应用程序中的所有 View Controller 迁移为使用 iOS 11 标准 searchController(在导航项上)。问题是当它作为表单在 iPad 上显示时,搜索
我在 UITableView 的标题中使用 UISearchController 的 UISearchBar。我的搜索工作正常,因为当我在搜索栏的字段中输入一些文本时,所有相关方法都会被调用,并且表格
我以编程方式创建了一个 searchBar 并将其添加到导航栏平铺 View 中。这是我的代码: UISearchController *searchController = [[UISearchC
在 UISearchDisplayController在 viewWillAppear: 中有一种方法可以在没有动画的情况下将其设置为事件状态方法,因此 View Controller 将推送已激活的
我正在向现有应用程序添加搜索栏。 我有一个表,其中填充了从服务器下载的数据,并且我正在使用新的 UISearchController。 我现在让搜索栏完全正常工作,并在用户输入搜索栏时显示一个新的过滤
我以编程方式将UISearchController添加到UIViewController中,当加载UIViewController时一切都很好,但是当我触摸UISearchBar时在UISearchC
我正在尝试发送搜索电影的请求,但是当我点击搜索栏写入文本时,我在 cellforrow 中崩溃,并且它没有调用 numberofrows 也没有调用请求。这是我到目前为止的代码: class InTh
我在 UITableViewController 上添加了一个搜索栏,但每次单击搜索栏时都会收到错误。 View 也变黑了.. 警告:尝试在 FindViewController 上呈现 OWSear
我在我的应用程序中使用 UISearchController,如下 this教程: 现在已经设置了自定义UITableViewCell。 UISearchController 弄乱了我的单元格。 看起
据我了解,UISearchController 的默认行为是: 点击搜索栏时,背景会变暗并显示“取消”按钮。 SearchResultsController 直到此时才显示。 SearchResult
我将 UISearchController searchBar 添加到 Controller 的 View 中,如下所示:self.view.addSubview(searchController.s
class PlaceSelectorViewController: UIViewController, GMSAutocompleteResultsViewControllerDelegate, U
我是一名优秀的程序员,十分优秀!