RxJava/RxAndroid -处理多个EditText更改



我有3个EditText字段,我已经为这些字段创建了3个可观察对象。

    Observable<CharSequence> o1 = RxTextView.textChanges(field1);
    Observable<CharSequence> o2 = RxTextView.textChanges(field2);
    Observable<CharSequence> o3 = RxTextView.textChanges(field3);

我想启用一个按钮,当这三个字段都有一些值在它。用户可以在字段中以任意顺序输入值。我怎么能做到呢?

<标题>编辑

我使用zip来实现。

Observable<CharSequence> o1 = RxTextView.textChanges(field1);
Observable<CharSequence> o2 = RxTextView.textChanges(field2);
Observable<CharSequence> o3 = RxTextView.textChanges(field3);
Observable.zip(o1, o2, o3, (c1, c2, c3) -> c1.length() > 0 && c2.length() > 0 && c3.length() > 0).subscribe(myButton::setEnabled)

当我在所有三个文本字段中输入内容时,上面的情况就会起作用。例:我在所有三个文本字段中输入了1个字符,然后按钮将被启用。但是当我删除三个字段中的任何一个字符时。zip将不会被调用,因为它将在调用订阅者上的onNext之前等待其他2个文本字段传输一些数据。当我删除任何文本框中的任何字符时我希望我的按钮再次被禁用。我怎样才能做到呢?

CombineLatest代替zip http://reactivex.io/documentation/operators/combinelatest.html

试试这个,这肯定会成功的。使用combineLatest。

//declare global variable
 private Subscription subscription = null;
 Observable<CharSequence> o1 = RxTextView.textChanges(field1);
 Observable<CharSequence> o2 = RxTextView.textChanges(field2);
 public void combineEvent(){
 subscription = Observable.combineLatest(o1, o2,
    new Func2<CharSequence, CharSequence, Boolean>() {
      @Override public Boolean call(CharSequence newEmail, CharSequence  newPassword) {
    //here you can validate the edit text
      boolean emailValid= !TextUtils.isEmpty(newEmail)
          &&    android.util.Patterns.EMAIL_ADDRESS.matcher(newEmail).matches();
        if(!emailValid){
          etEmailAddress.setError("Invalid Email");
        }
        boolean passValid = !TextUtils.isEmpty(newPassword)
            && newPassword.length() >6;
        if(!passValid){
          etPassword.setError("invalid password");
        }

        return emailValid && passValid;
      }
      }).subscribe(new Observer<Boolean>() {
    @Override public void onCompleted() {
    }
    @Override public void onError(Throwable e) {
  }
  @Override public void onNext(Boolean aBoolean) {
    if(aBoolean){
      //here you can enable your button or what ever you want.
      loginBtn.setEnabled(true);
    }else {
      loginBtn.setEnabled(false);
    }
  }
});
}

相关内容

  • 没有找到相关文章

最新更新