使用UISearchController

时间:2018-07-05 09:29:22

标签: ios swift uisearchbar ios11 uisearchcontroller

我已使用以下代码使用UISearchController实现了searchBar-

var searchController = UISearchController(searchResultsController: nil)
searchController.searchResultsUpdater = self
searchController.obscuresBackgroundDuringPresentation = false
searchController.searchBar.placeholder = "Search here..."
definesPresentationContext = true
searchController.searchBar.delegate = self
searchController.searchBar.sizeToFit()
if #available(iOS 11.0, *) {

self.navigationItem.searchController = searchController
} else {
// Fallback on earlier versions
navigationItem.titleView = searchController.searchBar
navigationItem.titleView?.layoutSubviews()
}

现在我有两个问题-

  1. SearchBar位于navigationBar下方(请参见下图),如何在使用UISearch bar实现searchBar时将searchBar置于NavigationBar的顶部。

  2. “取消”按钮没有出现在搜索栏的右侧。 enter image description here

3 个答案:

答案 0 :(得分:2)

我不认为您可以做到这一点。但是,您可以在打开菜单时激活搜索栏(不要忘记将searchController.hidesNavigationBarDuringPresentation设置为true):

override func viewDidAppear(_ animated: Bool) {
    super.viewDidAppear(animated)
    searchController.isActive = true
}

但是它将隐藏UINavigationBar,所以这不是您真正想要的。因此,也许更好,您可以创建一个自定义导航栏并隐藏本机导航栏。这是一个简单的示例:

1-创建一个快速的xib文件NavigationBarView,其中包含水平的UIStackView,背面的UIButton和固定的宽度以及UISearchBar

class NavigationBarView: UIView {

    var backAction: (()->Void)?
    @IBOutlet weak var searchBarView: UISearchBar!

    override func awakeFromNib() {
        super.awakeFromNib()

        // Customize your search bar
        self.searchBarView.showsCancelButton = true
    }

    @IBAction func backButtonPressed(_ sender: Any) {
        self.backAction?()
    }
}

2-创建UITableViewController而不是UIViewController,垂直UIStackView包含一个垂直高度为{64}和UITableView的视图:

class TableViewController: UIViewController, UITableViewDelegate, UITableViewDataSource, UISearchBarDelegate {

    @IBOutlet weak var tableView: UITableView!
    @IBOutlet weak var containerView: UIView!
    let navigationBarView: NavigationBarView = NavigationBarView.viewFromNib() // Custom helper to instantiate a view, see below

    override func viewDidLoad() {
        super.viewDidLoad()
        self.navigationController?.navigationBar.isHidden = true // hide the native UINavigationBar

        self.navigationBarView.backAction = {
            self.navigationController?.popViewController(animated: true)
        }
        self.navigationBarView.searchBarView.delegate = self
        self.navigationBarView.add(in: self.containerView) // Custom helper to put a view in a container view, see below

        // Other stuff     
        self.tableView.register(UITableViewCell.self, forCellReuseIdentifier: "Cell")
    }

这是我的助手:

extension UIView {
    static public func viewFromNib <GenericView: UIView> () -> GenericView {
        let className = String(describing: self)
        guard let instance = UINib(nibName: className, bundle: nil)
            .instantiate(withOwner: nil, options: nil).first as? GenericView else {
                // If this happens, it means the xcodeproj is broken
                fatalError("Ho no its broken!")
        }
        return instance
    }

    func add(in superView: UIView) {
        self.translatesAutoresizingMaskIntoConstraints = false
        superView.addSubview(self)
        self.topAnchor.constraint(equalTo: superView.topAnchor).isActive = true
        self.bottomAnchor.constraint(equalTo: superView.bottomAnchor).isActive = true
        self.leftAnchor.constraint(equalTo: superView.leftAnchor).isActive = true
        self.rightAnchor.constraint(equalTo: superView.rightAnchor).isActive = true
    }
}

答案 1 :(得分:0)

您可以尝试以下代码,如果遇到任何问题,请告诉我。

if self.searchController != nil {
            self.searchController.isActive = false
        }
        isSearching =  true
        self.searchController = UISearchController(searchResultsController:  nil)
        self.searchController.searchResultsUpdater = self
        self.searchController.delegate = self
        self.searchController.searchBar.delegate = self
        self.searchController.hidesNavigationBarDuringPresentation = false
        self.searchController.dimsBackgroundDuringPresentation = false
        self.navigationItem.titleView = searchController.searchBar
        self.definesPresentationContext = false

        self.searchController.searchBar.returnKeyType = .done

答案 2 :(得分:0)

  1. 具有此属性

    searchController.hidesNavigationBarDuringPresentation = true
    
  2. 存在间隙,因此它可能是白色的Canel按钮。您可以在Debugger Navigator(Cmd + 7)-> View UI Hierarcy中肯定地知道它。白色按钮文字可能是由于自定义导航栏样式引起的