EditText如何限制输入内容

其实我们经常遇到这样的需求,需要我们限制输入框的内容。比如,在做一个应用的登录模块的时候,可能就需要我们限制用户名和密码的格式。假如需求是用户名和密码必须都是英文字母或者数字组成,你会怎么做?可能你首先想到的是利用正则表达式,当然正则表达式可以做到,但是总有种杀鸡用牛刀的感觉。其实上面这个需求,我们只需要给EditText设置digits属性就可以了,用法如下:

<EditText
    android:id="@+id/et_test"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:digits="qwertyuiopasdfghjklzxcvbnmQWERTYUIOPASDFGHJKLZXCVBNM0123456789"
    />
是不是很简单,同样我们还可以通过代码的方式来限制输入框的内容,如下:
editText= (EditText) findViewById(R.id.et_test);
InputFilter[] filters = new InputFilter[1];
filters[0] = new MyInputFilter("qwertyuiopasdfghjklzxcvbnmQWERTYUIOPASDFGHJKLZXCVBNM0123456789");
editText.setFilters(filters);
public class MyInputFilter extends LoginFilter.UsernameFilterGeneric {
    private String mAllowedDigits;

    public MyInputFilter( String digits ) {
        mAllowedDigits = digits;
    }

    @Override
    public boolean isAllowed(char c) {
        if (mAllowedDigits.indexOf(c) != -1) {
            return true;
        }
        return false;
    }
}
假如还有位数限制的话,我们可以在配合 maxLength 属性来限制,上面两种做法达到的效果是完全一样的,这种做法的缺陷是假如输入的内容不符合我们的规范,是直接不能输入的,可是有的需求是不符合规范的也可以输入,在发送请求的时候才去验证,这时候我们就需要用正则表达式去做了。原来我们对密码的验证,如下:

/**
 * 检查密码是否合法
 *
 * @param pwd
 * @return
 */
public  boolean checkPassword( String pwd) {
    if (pwd == null || pwd.length() == 0) {
        Toast.makeText(this,"密码不能为空",Toast.LENGTH_SHORT).show();
        return false;
    }
    if (pwd.length() <6) {
        Toast.makeText(this,"密码长度不能少于6",Toast.LENGTH_SHORT).show();
        return false;
    }
    if (pwd.length() >18) {
        Toast.makeText(this,"密码长度不能超过18",Toast.LENGTH_SHORT).show();
        return false;
    }
    char[] c = pwd.toCharArray();
    for (int i = 0; i < c.length; i++) {//去中文
        if ((c[i] >= 0x4e00) && (c[i] <= 0x9fbb)) {
            Toast.makeText(this,"密码中不能含有中文字符",Toast.LENGTH_SHORT).show();
            return false;
        }
    }
    String regEx = "[a-zA-Z0-9]{6,18}$"; //表示英文字母或数字并且是6-18    Pattern pat = Pattern.compile(regEx);
    Matcher mat = pat.matcher(pwd);
    boolean rs = mat.matches();
    if (!rs) {
        Toast.makeText(this,"密码格式中可能含有其他非法字符",Toast.LENGTH_SHORT).show();
        return false;
    }
    return true;

}
好了就写这么多了~



  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值