Saripaar验证Android,多表单



我有3个表单在同一个活动(和布局),我想使用saripaar验证。这将验证三个表单,但它们不会独立验证。

这个布局:

  • 表单1:输入邮件和提交按钮。
  • Form2:输入验证码和提交按钮。
  • Form3:输入密码、密码确认和提交按钮。

我希望当您为form1按下submit时,只验证form1的规则,对form2和form3也是如此。

我有3个验证器对象,每个对象的逻辑都是相似的。例:

validatorEmail = new Validator(this);
editTextRecoveryEmail = (EditText) findViewById(R.id.editTextRecoveryEmail);
buttonRecoveryEmail = (Button) findViewById(R.id.buttonRecoveryEmail);
validatorEmail.setValidationListener(new ValidationListener() {
            @Override
            public void onValidationSucceeded() {
                // Enviar el email
            }
            @Override
            public void onValidationFailed(View failedView, Rule<?> failedRule) {
                String message = failedRule.getFailureMessage();
                if (failedView instanceof EditText) {
                    if (failedView.getId() == editTextRecoveryEmail.getId()) {
                        failedView.requestFocus();
                        ((EditText) failedView).setError(message);
                    }
                }
            }
        });
buttonRecoveryEmail.setOnClickListener(new OnClickListener() {
            @Override
            public void onClick(View v) {
                validatorEmail.validate();
            }
        });

这是我的完整活动代码:

/* Inicializamos los controles */
        editTextRecoveryEmail = (EditText) findViewById(R.id.editTextRecoveryEmail);
        editTextRecoveryCode = (EditText) findViewById(R.id.editTextRecoveryCode);
        editTextRecoveryPassword = (EditText) findViewById(R.id.editTextRecoveryPassword);
        editTextRecoveryPasswordConfirm = (EditText) findViewById(R.id.editTextRecoveryPasswordConfirm);
        buttonRecoverySubmit = (Button) findViewById(R.id.buttonRecoverySubmit);
        buttonRecoveryCode = (Button) findViewById(R.id.buttonRecoveryCode);
        buttonRecoveryEmail = (Button) findViewById(R.id.buttonRecoveryEmail);
    /* Objeto validador */
    validatorEmail = new Validator(this);
    validatorCode = new Validator(this);
    validatorSubmit = new Validator(this);
    validatorEmail.setValidationListener(new ValidationListener() {
        @Override
        public void onValidationSucceeded() {
            // Enviar el email
        }
        @Override
        public void onValidationFailed(View failedView, Rule<?> failedRule) {
            String message = failedRule.getFailureMessage();
            if (failedView instanceof EditText) {
                if (failedView.getId() == editTextRecoveryEmail.getId()) {
                    failedView.requestFocus();
                    ((EditText) failedView).setError(message);
                }
            }
        }
    });
    validatorCode.setValidationListener(new ValidationListener() {
        @Override
        public void onValidationSucceeded() {
            // Validar código
        }
        @Override
        public void onValidationFailed(View failedView, Rule<?> failedRule) {
            String message = failedRule.getFailureMessage();
            if (failedView instanceof EditText) {
                if (failedView.getId() == editTextRecoveryCode.getId()) {
                    failedView.requestFocus();
                    ((EditText) failedView).setError(message);
                }
            }
        }
    });
    validatorSubmit.setValidationListener(new ValidationListener() {
        @Override
        public void onValidationSucceeded() {
            // Validar Submit
        }
        @Override
        public void onValidationFailed(View failedView, Rule<?> failedRule) {
            String message = failedRule.getFailureMessage();
            if (failedView instanceof EditText) {
                if (failedView.getId() == editTextRecoveryPassword.getId()
                        || failedView.getId() == editTextRecoveryPasswordConfirm.getId()) {
                    failedView.requestFocus();
                    ((EditText) failedView).setError(message);
                }
            }
        }
    });
    /* Comportamiento del botón de Registro */
    buttonRecoveryEmail.setOnClickListener(new OnClickListener() {
        @Override
        public void onClick(View v) {
            validatorEmail.validate();
        }
    });
    /* Comportamiento del botón de Registro */
    buttonRecoveryCode.setOnClickListener(new OnClickListener() {
        @Override
        public void onClick(View v) {
            validatorCode.validate();
        }
    });
    /* Comportamiento del botón de Registro */
    buttonRecoverySubmit.setOnClickListener(new OnClickListener() {
        @Override
        public void onClick(View v) {
            validatorSubmit.validate();
        }
    });

这是一个有趣的问题。你需要在3个不同的控制器类中使用3个验证器来处理这种情况。

static class EmailController implements ValidationListener {
    @Email
    private EditText mEmailEditText;
    private Button mSubmitButton;
    private Context mContext;
    private Validator mValidator;
    public EmailController(@NonNull EditText emailEditText, @NonNull Button submitButton) {
        mEmailEditText = emailEditText;
        mSubmitButton = submitButton;
        mContext = emailEditText.getContext();
        mValidator = new Validator(this);
        mValidator.setValidationListener(this);
        mSubmitButton.setOnClickListener(new OnClickListener() {
            @Override
            public void onClick(View v) {
                validator.validate();
            }
        });
    }
    @Override
    public void onValidationSucceeded() {
        // Success...
    }
    @Override
    public void onValidationFailed(List<ValidationError> errors) {
        // Failure...
    }
}

您将需要两个以上-一个用于验证码,另一个用于密码。如果您希望与您的活动通信,请传递它或实现适当的侦听器接口。

相关内容

  • 没有找到相关文章

最新更新