searchController 异常行为

Posted

技术标签:

【中文标题】searchController 异常行为【英文标题】:searchController abnormal behaviour 【发布时间】:2018-06-23 12:32:25 【问题描述】:
class SearchMembers: UITableViewController, UISearchControllerDelegate 

    override func viewDidLoad() 
        super.viewDidLoad()

        navigationItem.backBarButtonItem = UIBarButtonItem(title: "", style: .plain, target: nil, action: nil)
        navigationItem.title = NSLocalizedString("MEMBERS", comment: "")

            let search = UISearchController(searchResultsController: nil)
            self.definesPresentationContext = true
            search.searchResultsUpdater = self
            search.dimsBackgroundDuringPresentation = false
            navigationItem.searchController = search
            navigationItem.hidesSearchBarWhenScrolling = false

    

当我从 tableview 单元格执行 segue 时,我可以看到搜索控制器应该是这样,但是当我从导航栏项执行 segue 时,我只看到一个没有搜索栏的空间。然后,我回到上一个视图,搜索控制器栏出现在那里。

如果我再次返回搜索视图,它将恢复正常行为。

可能的错误?

应该是:

编辑:

我意识到,如果我从 segue 设置中取消选择“动画”选项,我不会在 searchController 视图中看到空白区域,但当我返回主视图时仍然会看到空白区域

【问题讨论】:

您是否使用了两种不同类型的 segue,即显示和推送 @Scriptable All show segue @UtkuDalmaz,你有没有机会使用 UIAppearance 类来改变元素的外观? @T.Pasichnyk 不。我发现如果我导航到另一个选项卡然后返回主视图,这个问题就会消失。因此,当第一个应用程序使用此主视图加载时,就会出现问题。很有趣 您能向我们展示问题发生时调试视图层次结构的图像吗? 【参考方案1】:

检查您的 segue 是如何设置的。你有一个从视图控制器连接到视图控制器的segue,还是从tableview连接到另一个视图控制器,或者你有两个segue?在这种情况下,您应该使用一个 segue,只是在不同的地方触发它

performSegue(withIdentifier: "yourSegueIdentifier")

看看我为你快速编写的这段代码: 你也可以从我的 github 上试试,然后和你的比较一下。搜索栏在这两种情况下都应该出现。 https://github.com/verebes1/SearchBarHelp

import UIKit

class MainViewController: UITableViewController 

    var items = ["One", "Two", "Three"]

    override func viewDidLoad() 
        super.viewDidLoad()
        // Do any additional setup after loading the view, typically from a nib.
    

    //MARK: - Tableview methods
    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell 
        let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath)
        cell.textLabel?.text = items[indexPath.row]
        return cell
    

    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int 
        return items.count
    

    override func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) 
        performSegue(withIdentifier: "showMembers", sender: self)
    


    //MARK: - Segue setup
    override func prepare(for segue: UIStoryboardSegue, sender: Any?) 
        /* Put any preparation here if needed */
    

    //MARK: Navbar Button action
    @IBAction func searchBarButtonTapped(_ sender: Any) 
        performSegue(withIdentifier: "showMembers", sender: self)
    


和第二个viewController:

import UIKit

class SearchMembersController: UITableViewController, UISearchControllerDelegate 

    var members = ["First", "Second", "Third", "Fourth"]

    override func viewDidLoad() 
        super.viewDidLoad()

        navigationItem.backBarButtonItem = UIBarButtonItem(title: "", style: .plain, target: nil, action: nil)
        navigationItem.title = NSLocalizedString("MEMBERS", comment: "")

        let search = UISearchController(searchResultsController: nil)
        self.definesPresentationContext = true
        //search.searchResultsUpdater = self
        search.dimsBackgroundDuringPresentation = false
        navigationItem.searchController = search
        navigationItem.hidesSearchBarWhenScrolling = false
    


    // MARK: - Table view data source
    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int 
        return members.count
    

    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell 
        let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath)
        cell.textLabel?.text = members[indexPath.row]

        return cell
    

从评论中引用您的代码:

leftButton.addTarget(self, action: #selector(Profile.searchMembers), for: .touchUpInside) self.settingsButton.customView = leftButton 

这应该调用 performSegue(withIdentifier: "profileToMembers", sender: self) 而不是 Profile.searchMembers。可能会出错,您可以将其包装在 @objc 函数中,例如

@objc func segueToMembers() 
     performSegue(withIdentifier: "profileToMembers", sender: self) 
 

然后调用它

leftButton.addTarget(self, action: #selector(segueToMembers), for: .touchUpInside) self.settingsButton.customView = leftButton 

【讨论】:

Segue 是从视图控制器到视图控制器,我从导航栏项 (addTarget) 执行 segue leftButton.addTarget(self, action: #selector(Profile.searchMembers), for: .touchUpInside) self.settingsButton.customView = leftButton self.performSegue(withIdentifier: "profileToMembers", sender: self) 尝试只使用一个segue,然后按照我向你展示的那样执行Segue 我需要试试你的代码,你能上传到 github。就好像我尝试做类似的事情一样。我只用 performSegue 调用相同的 segue

以上是关于searchController 异常行为的主要内容,如果未能解决你的问题,请参考以下文章

SearchResultsController 出现在 UINavigationBar

智能合约实战 solidity 语法学习 13 [ 事件event emit日志logs 异常throw revertrequireassert] 附代码

智能合约实战 solidity 语法学习 13 [ 事件event emit日志logs 异常throw revertrequireassert] 附代码

智能合约实战 solidity 语法学习 13 [ 事件event emit日志logs 异常throw revertrequireassert] 附代码

iOS 13 UISearchBar 外观和行为

弹簧安全 LDAP。使用 SearchControls.OBJECT_SCOPE 代替 SearchControls.SUBTREE_SCOPE