4

目前我有两个编辑文本,假设我想对空编辑文本检查进行验证。什么是运行时验证的更好方法。

我的代码是;

    final EditText ev1 = (EditText) findViewById(R.id.editText1);
    final EditText ev2 = (EditText) findViewById(R.id.editText2);


    ev1.setOnFocusChangeListener(new OnFocusChangeListener() {

    @Override
    public void onFocusChange(View rv, boolean hasFocus) {
    if(!hasFocus && ev1.getText().length()==0)
    {    
        ev1.requestFocus();
        ev2.clearFocus();
    }
    }
});

在第二个editText的这个onclick中,当First Edittext为空时,它会清除第二个EditText的焦点,但键盘输入总是在第二个文本中完成,我们永远无法在第一个文本中获得焦点。

请不要为不同的 EditText 建议不同的不同焦点侦听器,因为这个 editText 也可以动态添加。

在两个文本中都有焦点!!!!

更清楚:在失去焦点之前验证 ev1 只是简单的事情,在输入任何字符之前不允许其他视图获得焦点。

4

4 回答 4

10
    final EditText ev1 = (EditText) findViewById(R.id.editText1);
    final EditText ev2 = (EditText) findViewById(R.id.editText2);

    ev1.setOnFocusChangeListener(new OnFocusChangeListener() {      
        @Override
        public void onFocusChange(View rv, boolean hasFocus) {
            if(!hasFocus && ev1.getText().length()==0)
            {    
                  new Handler().postDelayed(new Runnable() {

                  @Override
                  public void run() {
                       ev2.clearFocus();
                   ev1.requestFocus();

                  }
            }, 100);

         }
      }
    });
于 2013-01-11T07:16:24.017 回答
0

试试这个 :

编辑 :

        final EditText ev1,ev2,ev3,ev4,ev5,ev6;

        ev1 = (EditText) findViewById(R.id.editText1);
        ev2 = (EditText) findViewById(R.id.editText2);
        ev3 = (EditText) findViewById(R.id.editText3);
        ev4 = (EditText) findViewById(R.id.editText4);
        ev5 = (EditText) findViewById(R.id.editText5);
        ev6 = (EditText) findViewById(R.id.editText6);

        setValidateAction(ev2);
        setValidateAction(ev3);
        setValidateAction(ev4);
        setValidateAction(ev5);
        setValidateAction(ev6);

声明这个方法:

public void setValidateAction(final EditText edit_action) {
        edit_action.setOnFocusChangeListener(new OnFocusChangeListener() {
            public void onFocusChange(View v, boolean hasFocus) {
                if(hasFocus && ev1.getText().length()==0){    
                    ev1.requestFocus();               
                }
            }
        });
}            

谢谢。

于 2013-01-11T07:11:54.593 回答
0

我已经接受了具有两个文本框的 xml,并尝试了这种方式来解决您的问题。

检查下面的代码,告诉我你可以吗?

    setContentView(R.layout.activity_main);
    final EditText password = (EditText)findViewById(R.id.editText1);
    final EditText confirmpassword = (EditText)findViewById(R.id.editText2);

    password.addTextChangedListener(new TextWatcher() {

        public void onTextChanged(CharSequence s, int start, int before, int count) {
            if(password.getText().toString().trim().length()==0)
            {
                confirmpassword.setText("");
            }
        }

        public void beforeTextChanged(CharSequence s, int start, int count,
                int after) {
        }

        public void afterTextChanged(Editable s) {
        }
    });
    confirmpassword.setOnFocusChangeListener(new OnFocusChangeListener() {

        public void onFocusChange(View v, boolean hasFocus) {
            if(hasFocus && password.getText().toString().trim().length()==0)
            {
                // First fill password
                password.requestFocus();
            }
        }
    });
于 2013-01-11T07:12:44.537 回答
0
 add.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v)
            {
                if (isEmpty(name)) {
                    return;
                }
            }
    });


public boolean isEmpty(EditText... editTexts)
    {
        boolean res=true;
        for (EditText editText:editTexts) {
            if (TextUtils.isEmpty(editText.getText())) {
                editText.setError("Fill field");
                editText.requestFocus();

                res = true;
                break;
            }
            else {
                res = false;
            }
        }
        return res;
    }
于 2021-02-19T14:25:54.997 回答