RxSwift - 實(shí)時檢測textFiled輸入值

RxSwift版實(shí)現(xiàn)實(shí)時檢測textFiled輸入值呈現(xiàn)不同狀態(tài)

rx_text
import UIKit
import RxCocoa
import RxSwift

class Demo6: UIViewController {
    
    @IBOutlet weak var usernameTextfield: UITextField!
    @IBOutlet weak var passwordTextfield: UITextField!
    @IBOutlet weak var registerButton: UIButton!
   
    let disposeBag = DisposeBag()
    
    override func viewDidLoad() {
        super.viewDidLoad()
        
        let nameObserable = usernameTextfield.rx_text.shareReplay(1).map {
            $0.characters.count > 6
        }
        let pwdObserable = passwordTextfield.rx_text.shareReplay(1).map {
            $0.characters.count >= 8
        }
        
        _ = nameObserable.bindTo(usernameTextfield.ex_validState).addDisposableTo(disposeBag)
        _ = pwdObserable.bindTo(passwordTextfield.ex_validState).addDisposableTo(disposeBag)
        
        _ = Observable.combineLatest(nameObserable, pwdObserable) {$0 && $1}.bindTo(registerButton.ex_validState).addDisposableTo(disposeBag)
        
        _ = registerButton.rx_tap.shareReplay(1).subscribeNext { [weak self] in
            
            self?.buttonTapped()
        }
    }

    func buttonTapped()  {
         print("Button tapped")
    }
}
/// 擴(kuò)展
extension UITextField {
    var ex_validState:AnyObserver<Bool>{
        return UIBindingObserver(UIElement: self) { textfield, valid in
            textfield.backgroundColor = valid ? UIColor.clearColor() : UIColor.grayColor()
           textfield..textColor= valid ? UIColor.grayColor() : UIColor.whiteColor()
            }.asObserver()
    }
}
extension UIButton {
    var ex_validState:AnyObserver<Bool>{
        return UIBindingObserver(UIElement: self) { button, valid in
            button.enabled = valid
            button.backgroundColor = valid ? UIColor.redColor() : UIColor.darkGrayColor()
            }.asObserver()
    }
}

常規(guī)做法

因?yàn)閠extField代理事件不能做到實(shí)時檢測,所以...
相比RxSwift太遜色...如果還要繼續(xù)進(jìn)行其他交互,不可想象代碼的增加量及維護(hù)性

import UIKit
class Demo6: UIViewController {
    
    @IBOutlet weak var usernameTextfield: UITextField! {
        didSet {
            usernameTextfield.backgroundColor = UIColor.grayColor()
            usernameTextfield.textColor = UIColor.whiteColor()
            usernameTextfield.addTarget(self, action: #selector(Demo6.textFieldDidChange(_:)), forControlEvents: .EditingChanged)
        }
    }
    @IBOutlet weak var passwordTextfield: UITextField! {
        didSet {
            passwordTextfield.backgroundColor = UIColor.grayColor()
            passwordTextfield.textColor = UIColor.whiteColor()
            passwordTextfield.addTarget(self, action: #selector(Demo6.textFieldDidChange(_:)), forControlEvents: .EditingChanged)
        }
    }
    
    @IBOutlet weak var registerButton: UIButton! {
        didSet {
            registerButton.userInteractionEnabled = false
            registerButton.backgroundColor = UIColor.grayColor()
        }
    }

    override func viewDidLoad() {
        super.viewDidLoad()

    }
    
    func textFieldDidChange(sender:UITextField) {
        
        let usernameCount = usernameTextfield.text?.characters.count
        let passwordCount = passwordTextfield.text?.characters.count
        
        usernameTextfield.backgroundColor = usernameCount > 6 ? UIColor.clearColor() : UIColor.grayColor()
        usernameTextfield.textColor = usernameCount > 6 ? UIColor.grayColor() : UIColor.whiteColor()

        passwordTextfield.backgroundColor = passwordCount >= 8 ? UIColor.clearColor() : UIColor.grayColor()
        passwordTextfield.textColor = passwordCount >= 8 ? UIColor.grayColor() : UIColor.whiteColor()
        
        if usernameCount > 6 && passwordCount >= 8 {
            registerButton.userInteractionEnabled = true
            registerButton.backgroundColor = UIColor.redColor()
        } else {
            registerButton.userInteractionEnabled = false
            registerButton.backgroundColor = UIColor.grayColor()
        }
    }
    
    @IBAction func buttonTapped(sender: AnyObject) {
         print("Button tapped")
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

推薦閱讀更多精彩內(nèi)容