UISearchBar resignFirstResponder无法正常工作

时间:2018-03-02 10:23:23

标签: ios swift uiviewcontroller uisearchbar

UIViewController需要在viewWillDisappearviewDidDisappear方法中隐藏键盘。消失后UIViewController留在记忆中,可以再次出现。首次出现UISearchBar不是firstResponder,键盘被隐藏。但如果我弹出显示键盘的UIViewController然后再按一下键盘 - 键盘不会被隐藏,但是我打电话给:

override func viewDidLoad() {
    super.viewDidLoad()
    instrumentsTableView.register(UINib(nibName: kDealsFilterInstrumentTableViewCellNib, bundle: nil), forCellReuseIdentifier: kDealsFilterInstrumentTableViewCellReusableId)
    instrumentsTableView.dataSource = self
    instrumentsTableView.delegate = self
}

override func viewDidDisappear(_ animated: Bool) {
    super.viewDidDisappear(animated)
    if presenter.numberOfInstruments != 0 {
        instrumentsTableView.scrollToRow(at: IndexPath(row: 0, section: 0), at: .top, animated: false)
    }
    KeyboardManager.shared.unsubscribe()
    instrumentsSearchBar.text = ""
    presenter.findInstruments(with: "") //just sets settings to default/ reloads data


    instrumentsSearchBar.endEditing(true)
    instrumentsSearchBar.resignFirstResponder()
    view.endEditing(true)
    view.resignFirstResponder()
}

override func viewWillDisappear(_ animated: Bool) {
    super.viewWillDisappear(animated)
}

override func viewDidAppear(_ animated: Bool) {
    super.viewDidAppear(animated)
    KeyboardManager.shared.subscribe(self)
}

KeyboardManager - 如果键盘的状态发生了变化(如果相关),则发送通知:

final class KeyboardManager {

    private init() {
        NotificationCenter.default.addObserver(self, selector: #selector(keyboardWillShow(_:)), name: Notification.Name.UIKeyboardWillShow, object: nil)
        NotificationCenter.default.addObserver(self, selector: #selector(keyboardWillHide(_:)), name: Notification.Name.UIKeyboardWillHide, object: nil)
    }

    static let shared = KeyboardManager()

    @objc private func keyboardWillShow(_ notification: Notification) {
        if let keyboardSize = notification.userInfo?[UIKeyboardFrameEndUserInfoKey] as? NSValue {
            let height = keyboardSize.cgRectValue.height
            keyboardHeight = height
            keyboardState = .shown
        }
    }

    @objc private func keyboardWillHide(_ notification: Notification) {
        keyboardHeight = 0
        keyboardState = .hidden
    }

    private weak var subscriber: KeyboardManagerDelegate?

    func subscribe(_ delegate: KeyboardManagerDelegate) {
        subscriber = delegate
    }

    func unsubscribe() {
        subscriber = nil
    }

    private var keyboardHeight: CGFloat = 0

    private var keyboardState: KeyboardState = .hidden {
        didSet {
            if keyboardState != oldValue {
                subscriber?.keyboardDidChange(state: keyboardState, height: keyboardHeight)
            }
        }
    }
}

enum KeyboardState {
    case shown
    case hidden
}

protocol KeyboardManagerDelegate: class {
    func keyboardDidChange(state: KeyboardState, height: CGFloat)
}

我已尝试在viewWillAppearviewWillDisappear中使用此代码 - 但UISearchBar仍为firstResponder。如果我弹出键盘被隐藏 - 它会保持隐藏状态。可能是什么问题?

截屏:

enter image description here

Sample project with the same issue on bitbucket

2 个答案:

答案 0 :(得分:0)

对于键盘问题,这可以正常工作,

10.10.10.10

self.view.endEditing(true) viewWillDisappear

中写下此内容

答案 1 :(得分:0)

我已经尝试过您的代码:Sample project with the same issue on bitbucket并且按预期正常工作。

这是代码。

class ViewController: UIViewController {

    @IBAction func btnShowSearch(button: UIButton) {
        if let search = self.storyboard?.instantiateViewController(withIdentifier: "SeachBarViewController") {
            self.navigationController?.pushViewController(search, animated: true)
        }
    }

}

// SeachBarViewController
class SeachBarViewController: UIViewController {

    @IBOutlet var searchBar: UISearchBar!

    override func viewDidDisappear(_ animated: Bool) {
        super.viewDidDisappear(animated)
        attemptToHidKeyboard()
    }

    override func viewWillDisappear(_ animated: Bool) {
        super.viewWillDisappear(animated)
        attemptToHidKeyboard()
    }

    override func viewWillAppear(_ animated: Bool) {
        super.viewWillAppear(animated)
        attemptToHidKeyboard()
    }

    override func didMove(toParentViewController parent: UIViewController?) {
        if parent == nil {
            attemptToHidKeyboard()
        }
    }

    override func willMove(toParentViewController parent: UIViewController?) {
        if parent == nil {
            attemptToHidKeyboard()
        }
    }


    private func attemptToHidKeyboard() {
        self.searchBar.resignFirstResponder()
        self.searchBar.endEditing(true)
        self.view.resignFirstResponder()
        self.view.endEditing(true)
    }
}

结果如下:

enter image description here