7

我已经向 UIAlertController 添加了一个 UITextField,但shouldChangeCharactersInRange不会被解雇。为什么?我设置了代表。

let alertController = UIAlertController(title: "", message: "xxx", preferredStyle: .Alert)

self.presentViewController(alertController, animated:true, completion:nil)
let textField = UITextField()
textField.delegate = self
alertController.addTextFieldWithConfigurationHandler(nil)

在同一个班级中,代表:

func textField(textField: UITextField!,
    shouldChangeCharactersInRange range: NSRange,
    replacementString string: String!) -> Bool {
4

2 回答 2

13

您为其设置委托的文本字段与添加到警报控制器的文本字段不同。基本上,您正在创建一个新的 UITextField 实例,但从不给它一个框架,或者将它添加到视图层次结构中。同时,您正在使用addTextFieldWithConfigurationHandler()向警报控制器添加一个文本字段,但您从未为此文本字段设置委托。我相信这就是你想要的:

let alertController = UIAlertController(title: "", message: "xxx", preferredStyle: .Alert)

alertController.addTextFieldWithConfigurationHandler {[weak self] (textField: UITextField!) in
    textField.delegate = self
}

self.presentViewController(alertController, animated:true, completion:nil)
于 2014-07-20T17:19:06.323 回答
1

我无法使用UITextFieldDelegate. 委托已正确设置,但未在 UIAlertController 中为 UITextField 调用。

基于此处的答案How do I validate TextFields in an UIAlertController? 我了解到您可以在编辑更改时使用addTargetforUIControl.Event.editingChanged来调用选择器。

let alertController = UIAlertController(title: "Title", message: "message", preferredStyle: .alert)

alertController.addTextField { (textField : UITextField!) -> Void in

    /*
     * Alternative to UITextFieldDelegate
     */
    textField.addTarget(alertController, action: #selector(alertController.textDidChange), for: .editingChanged)
}

let searchAction = UIAlertAction(title: "Search", style: .default)
let cancelAction = UIAlertAction(title: "Cancel", style: .cancel, handler: nil )

alertController.addAction(searchAction)
alertController.addAction(cancelAction)

present(searchAlertController, animated: true)

您可以扩展或继承 UIAlertController 以添加选择器:

extension UIAlertController {

    @objc func textDidChange() {
        guard let textField = textFields?.first else { return }
        guard let searchAction = actions.first(where: { $0.title == "Search" }) else { return }
        let text = textField.text?.trimmingCharacters(in: .whitespacesAndNewlines) ?? ""
        searchAction.isEnabled = !text.isEmpty
    }

}
于 2020-04-29T23:24:11.817 回答