【问题标题】:searchController abnormal behavioursearchController 异常行为
【发布时间】: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 不。我发现如果我导航到另一个选项卡然后返回主视图,这个问题就会消失。因此,当第一个应用程序使用此主视图加载时,就会出现问题。很有趣
  • 您能向我们展示问题发生时调试视图层次结构的图像吗?

标签: ios swift uisearchcontroller


【解决方案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
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2012-12-05
  • 2017-01-22
  • 2013-04-14
  • 2014-01-29
  • 1970-01-01
  • 2011-01-13
  • 2010-10-14
相关资源
最近更新 更多