Как вы получаете сигнал каждый раз, когда свойство текста UITextField изменяется в ReactiveCocoa 5

Как вы получаете сигнал от внесенных пользователем и программно внесенных изменений в UITextFieldtext имущество? Используя continuousTextValues сообщает только о сигнале, когда пользователь инициировал изменение. Если вы установите textField.text программно сигнал не срабатывает.

Вот как я пользуюсь continuousTextValues:

textField.reactive.continuousTextValues.observeValues { value in
    print("Value: \(value)")
}

Это не срабатывает, если я установлю text вручную:

textField.text = "Test"

3 ответа

Сигнал continuousTextValuesбудет срабатывать только при вводе пользователем с клавиатуры. Вы можете попробовать это:

var characters = MutableProperty("")

tf.reactive.text <~ characters
tf.reactive.continuousTextValues.observeValues { [weak characters = characters] (text) in
   characters?.value = text!
}
tf.reactive.textValues.observeValues { [weak characters = characters] (text) in
   characters?.value = text!
}

characters.producer.skip(while: { $0.isEmpty }).startWithValues { (text) in
   log.debug("text = \(text)")
}

characters.value = "shaw"

Вместо изменения значения текста с textField.textВы должны создать сигнал, привязать его к текстовому полю и изменить значение сигнала. Я использовал Signal труба, но если вам нужно сохранить программно измененное значение, вы можете использовать MutableProperty,

class MyViewController: UIViewController {
    var textField: UITextField!
    private let textFieldValuePipe = Signal<String?, NoError>.pipe()
    var textFieldValueSignal: Signal<String?, NoError>!

    override func viewDidLoad() {
        // Initialize the text field
        // ...

        // Bind the text of the text field to the signal pipe's output
        textField.reactive.text <~ textFieldValuePipe.output

        // A signal of text values emitted by the text field upon end of editing.
        let textFieldValuesSignal = textField.reactive.textValues

        // A signal of text values emitted by the text field upon any changes.
        let textFieldContinuousValuesSignal = textField.reactive.continuousTextValues

        // Merge the relevant signals
        textFieldValueSignal = Signal.merge(textFieldValuesSignal, textFieldContinuousValuesSignal, textFieldValuePipe.output)

        // This will print the text field's value when it's changed by the user or programmatically
        textFieldValueSignal.observeValues { value in
            print(value ?? "nil")
        }
    }

    // Use this to change the text field's value programmatically
    func setTextFieldText(_ text: String?) {
        textFieldValuePipe.input.send(value: text)
    }

}

Чтобы прослушать программные изменения в текстовом свойстве:

let textField = UITextField()
let signal = textField.reactive.signal(forKeyPath: #keyPath(UITextField.text)).map { $0 as? String }
signal.observeValues { print($0) }
textField.text = "Hello World"

Обратите внимание, что вам все еще нужно соблюдать continuousTextValues если вы хотите наблюдать изменения из-за действий пользователя.

Вы можете прослушивать textFields с помощью свойства rac_textSignal.

[self.someTextField.rac_textSignal subscribeNext:^(NSString* text) {       
     NSLog(@"%@", text); 
}];

Каждый раз, когда тексты textField изменяются, будет вызываться это закрытие.

После установки текста вызовите событие редактирования: textField.sendActions(for: .editingChanged)

Другие вопросы по тегам