您好,登錄后才能下訂單哦!
之前做商城應用時,會有對用戶資料的設置情況進行限制,如下:
(1)用戶郵箱,應當只允許輸入英文字母,數字和@.兩個符號,
(2)用戶手機,應當只能輸入數字,禁止輸入其他字符。
(3)用戶密碼,應當不能輸入空格以及中文字符等。
針對用戶郵箱以及用戶手機,有以下兩種解決方案:
它表示EditText能夠接受的字符集合。通過配置此屬性,就可以實現只允許輸入指定的字符。這里列舉上述三種場景下的android:digits配置。
場景一:只允許輸入數字 android:digits="0123456789"
場景二:只允許輸入數字和英文字母 android:digits="0123456789abcdefghigklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"
場景三:只允許輸入數字,英文字母和@.兩個符號 android:digits="0123456789abcdefghigklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ@."
使用android:digits屬性有幾個需要注意的地方:
android:digits屬性是隱藏的,無法直接在EditText的可視化屬性列表中找到。只能直接在XML布局文件中配置。當在XML中增加了這項配置后,才可以在EditText的可視化屬性列表中找到。
android:digits屬性中的字符順序沒有影響,例如只允許輸入數字時,可以用android:digits="0123456789",也可以用android:digits="9876543210"。
android:digits屬性中允許有重復字符,有重復字符在使用效果上沒有影響。例如android:digits="aaaAAA"和android:digits="aA"效果是一樣的。
android:digits屬性只能設置允許輸入哪些字符,不能設置禁止輸入哪些字符,也就是說android:digits屬性只能設置白名單,不能設置黑名單。
帶有中文輸入法的手機,通常輸入法會有三種類型的軟鍵盤:中文鍵盤,英文鍵盤和數字鍵盤,不同鍵盤類型之間可以切換。雖然android:digits屬性可以讓EditText中只允許輸入指定類型的字符,但并不能控制軟鍵盤彈出時的類型。例如在設置android:digits只允許輸入數字時,可能彈出的軟鍵盤是英文鍵盤或中文鍵盤,需要用戶點擊切換到數字鍵盤后才可以輸入;在設置android:digits只允許輸入英文和數字時,可能彈出的軟鍵盤是中文鍵盤,同樣需要用戶點擊切換到英文鍵盤和數字鍵盤后才可以輸入。如果能在軟鍵盤顯示時就直接跳到對應鍵盤類型,不需要用戶切換就更好了。
當設置android:inputType為number時,輸入法開啟時會自動切換到數字鍵盤。當設置為這里的其他幾個選項時,輸入法開啟時會自動切換到英文字母鍵盤。這里列舉上述三種場景下的android:inputType配置。
場景一:只允許輸入數字 android:inputType="number"。實際上,當inputType設置為number后,EditText中就只能輸入數字了,那么android:digits="0123456789"也不用設置了。 如果android:inputType="number"和android:digits同時設置,則實際可以輸入的字符以android:digits配置為準。例如android:digits="01234567+-",則可以輸入的字符為"01234567+-",這時如果同時設置了android:inputType="number",可以達到自動切換到數字鍵盤的目的。
場景二:只允許輸入數字和英文字母 android:inputType="textVisiblePassword"。其他幾個選項似乎都不太合適,textCapxxx的會有大小寫的約束,textPassword顯然只能用在密碼輸入框中,如果不介意軟鍵盤中多幾個符號,textEmailAddress倒也可以用在這里。
場景三:只允許輸入數字,英文字母和@.兩個符號 android:inputType="textEmailAddress"。
下面通過代碼演示通過此種方法設置不能輸入空格以及中文字符等。
一般對EditText的操作及處理都是用addTextChangedListener方法來對EditText進行監聽,之后在監聽方法中去做處理.這里也打算用這個種方法來做,大體的思路是監聽EditText中輸入的內容,然后將不是中文的部分清除掉,也就是置為空。
package com.example.panchengjia.limittext;import android.text.Editable;import android.text.TextWatcher;import android.widget.EditText;/** * Created by panhouye on 2017/5/7 0007. */public class LimitInputTextWatcher implements TextWatcher { /** * et */ private EditText et = null; /** * 篩選條件 */ private String regex; /** * 默認的篩選條件(正則:不能輸入中文和空格) * \u4E00-\u9FA5匹配中文\u0020匹配空格 */ private String DEFAULT_REGEX = "[\u4E00-\u9FA5\u0020]"; /** * 構造方法 * * @param et */ public LimitInputTextWatcher(EditText et) { this.et = et; this.regex = DEFAULT_REGEX; } /** * 構造方法 * * @param et et * @param regex 篩選條件 */ public LimitInputTextWatcher(EditText et, String regex) { this.et = et; this.regex = regex; } @Override public void beforeTextChanged(CharSequence charSequence, int i, int i1, int i2) { } @Override public void onTextChanged(CharSequence charSequence, int i, int i1, int i2) { } @Override public void afterTextChanged(Editable editable) { String str = editable.toString(); String inputStr = clearLimitStr(regex, str); et.removeTextChangedListener(this); // et.setText方法可能會引起鍵盤變化,所以用editable.replace來顯示內容 editable.replace(0, editable.length(), inputStr.trim()); et.addTextChangedListener(this); } /** * 清除不符合條件的內容 * * @param regex * @return */ private String clearLimitStr(String regex, String str) { return str.replaceAll(regex, ""); } }
package com.example.panchengjia.limittext;import android.support.v7.app.AppCompatActivity;import android.os.Bundle;import android.widget.EditText;public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); EditText et = (EditText) findViewById(R.id.et); //使用LimitInputTextWatcher中默認的輸入規則 et.addTextChangedListener(new LimitInputTextWatcher(et)); EditText ett = (EditText) findViewById(R.id.ett); //設置只能輸入中文 ett.addTextChangedListener(new LimitInputTextWatcher(ett,"[^\u4E00-\u9FA5]")); } }
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。