最近在做的項目中用戶編輯資料的時候不希望用戶輸入表情,如果用戶輸入表情的話上傳給后臺要報錯,所以需要我們前端做一個判斷。下面就來說一下怎么在EditText中屏蔽表情吧。
網上有很多這樣的列子但是一不小心就會掉進坑里面,比如繼承EditText,重寫addTextChangedListener()方法。可能當時你測試的時候沒有什么問題,但是項目上線后就會有很多問題,錯誤率很高,但是查看友盟后臺的時候好像是截取字符串長度方面的錯誤。所以建議大家不要使用那個方法了。
因為上面的方法不行,肯定要想其他的解決方案了。這里想到了通過過濾器來攔截用戶輸入的字符,可以避免截取字符串角標越界的問題。
InputFilter inputFilter= new InputFilter() { Pattern emoji = Pattern.compile("[/ud83c/udc00-/ud83c/udfff]|[/ud83d/udc00-/ud83d/udfff]|[/u2600-/u27ff]", Pattern.UNICODE_CASE | Pattern.CASE_INSENSITIVE); @Override public CharSequence filter(CharSequence source, int start, int end, Spanned dest, int dstart, int dend) { Matcher emojiMatcher = emoji.matcher(source); if (emojiMatcher.find()) { // Toast.makeText(MainActivity.this,"不支持輸入表情", 0).show(); MyToast.showText("不支持輸入表情"); return ""; } return null; } };然后給editText設置filter,這里給editText設置了兩個filter第一個是屏蔽表情,第二個是設置用戶輸入多少字數的限制
//給editText設置filteredit_name.setFilters(new InputFilter[]{inputFilter,new InputFilter.LengthFilter(12)});當然這里最后要提醒大家一點就是,這樣屏蔽的表情符號肯定還是不能夠百分之百的屏蔽完全的。所以最后我們只能選擇讓用戶填寫英文,漢字,和數字了。下面是過濾的代碼
InputFilter inputFilter=new InputFilter() { Pattern pattern = Pattern.compile("[^a-zA-Z0-9//u4E00-//u9FA5_]"); @Override public CharSequence filter(CharSequence charSequence, int i, int i1, Spanned spanned, int i2, int i3) { Matcher matcher= pattern.matcher(charSequence); if(!matcher.find()){ return null; }else{ MyToast.showText("只能輸入漢字,英文,數字"); return ""; } } };ok,就是這么簡單。希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。
新聞熱點
疑難解答