在移動端通常不多使用複雜的表單,通常針對於屬性的更改都會打開一個新的頁面進行更改。雖然很少,可是也會有。若是一個頁面要輸入的內容包括姓名、地址、郵箱、手機號等,對各個屬性的驗證會很是麻煩,而且很是的不優雅。java
因而,saripaar
就出現了,一種基於規則的Android UI
輸入驗證庫,經過註解便可標註驗證規則。android
使用過程當中發現只有四個字:簡單好用。可是官方對註解的使用並無一份完整的文檔,故參考源碼整理了現有的全部註解(基於版本2.0.3
)。git
第一步固然是導入依賴啦,可經過implementation 'com.mobsandgeeks:android-saripaar:(latest version)'
導入saripaar
,將(latest version)
替換爲最新版本便可。github
對須要進行驗證的可輸入View
加上註解來標註驗證規則,例正則表達式
@Length(min = 6, max = 9) private AppCompatEditText et1;
該註解表示et1
中的輸入內容長度只能在6到9的閉區間。數組
Validator
mValidator = new Validator(this); mValidator.setValidationListener(this);
Validator
負責驗證給定容器中的View
,一般容器爲Activity
或Fragment
。但也能夠用包含View
的其餘類做爲容器。框架
ValidationListener
public class MainActivity extends AppCompatActivity implements Validator.ValidationListener { // Code… @Override public void onValidationSucceeded() { Toast.makeText(this, "成功了!", Toast.LENGTH_LONG).show(); } @Override public void onValidationFailed(List<ValidationError> errors) { Toast.makeText(this, "失敗了!", Toast.LENGTH_LONG).show(); } }
ValidationListener
用戶監聽回調結果,並進行相應的處理。dom
btn.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { mValidator.validate(); } });
其他的高級用法在此不作介紹,該文章主要介紹各個註解的使用。ide
@AssertFalse
用於判斷輸入內容是否爲false
。this
CheckBox
RadioButton
RadioGroup
sequence
:肯定規則的斷定順序,當單個View
有多個規則時生效messageResId
:錯誤提示文字的資源文件IDmessage
:錯誤提示文字@AssertTrue
用於判斷輸入內容是否爲true
。
CheckBox
RadioButton
RadioGroup
@Checked
用於判斷輸入內容是否爲預設值,默認預設值爲true
。
CheckBox
RadioButton
RadioGroup
value
:用於設置預設值,默認爲true
@ConfirmEmail
判斷當前輸入內容與被@Email
註解的View
的內容是否一致。
注:當前容器所持有的被@Email
註解的View
必須且只容許有一個。
TextView
@ConfirmPassword
判斷當前輸入內容與被@Password
註解的View
的內容是否一致。
注:當前容器所持有的被@Password
註解的View
必須且只容許有一個。
TextView
@CreditCard
判斷輸入內容是否符合信用卡卡號規則。
TextView
cardTypes
:是一個數組,用於肯定信用卡的類型,每種類型對應着不一樣的正則表達式
Type.AMEX
,美國運通卡,對應着^(3[47]\d{13})$
Type.DINERS
,大萊信用卡,對應着^(30[0-5]\d{11}|3095\d{10}|36\d{12}|3[8-9]\d{12})$
Type.DISCOVER
,發現卡,對應着^(6011\d{12})$
、^(64[4-9]\d{13})$
和^(65\d{14})$
Type.MASTERCARD
,萬事達卡,對應着^(5[1-5]\d{14})$
Type.VISA
,簽證卡,對應着^(4)(\d{12}|\d{15})$
Type.NONE
,不容許任何內置的信用卡,適用於自定義信用卡類型@DecimalMax
限制輸入內容的最大值,輸入內容會被強轉爲Double
類型,若輸入文字不符合Double
類型,會報ConversionException
異常。
TextView
value
:double
類型,最大值。@DecimalMin
限制輸入內容的最小值,輸入內容會被強轉爲Double
類型,若輸入文字不符合Double
類型,會報ConversionException
異常。
TextView
value
:double
類型,最小值。@Digits
判斷輸入內容是否爲數字,可定義整數部分以及小數部分的最大位數。
TextView
integer
:整數部分最大位數fraction
:小數部分最大位數String.format("(\\d{0,%d})(\\.\\d{1,%d})?", integer, fraction);
@Domain
判斷輸入內容是不是一個有效的域名。
TextView
allowLocal
:本地地址是否有效,默認爲false
@Email
判斷輸入內容是不是一個有效的郵箱地址。
TextView
allowLocal
:本地地址是否有效,默認爲false
@Future
判斷輸入的時間是不是將來時間(與當前時間相比)。輸入的時間必須知足相應的格式。
TextView
dateFormat
:時間的格式,默認爲dd-MM-yyyy
,如下爲saripaar
提供的格式(可自定義)
DateFormats.DMY
:dd-MM-yyyy
DateFormats.YMD
:yyyy-MM-dd
DateFormats.MDY
:MM-dd-yyyy
DateFormats.DMY_TIME_12_HOURS
:dd-MM-yyyy hh:mm aa
DateFormats.YMD_TIME_12_HOURS
:yyyy-MM-dd hh:mm aa
DateFormats.MDY_TIME_12_HOURS
:MM-dd-yyyy hh:mm aa
DateFormats.DMY_TIME_24_HOURS
:dd-MM-yyyy kk:mm
DateFormats.YMD_TIME_24_HOURS
:yyyy-MM-dd kk:mm
DateFormats.MDY_TIME_24_HOURS
:MM-dd-yyyy kk:mm
dateFormatResId
:時間格式的資源ID@IpAddress
判斷輸入的內容是不是一個IP
,IPv4
或IPv6
TextView
@Isbn
判斷輸入的內容是不是一個Isbn
,即國際標準書號。
TextView
@Length
限制輸入內容的文本長度,可自定義最大長度和最小長度。
TextView
min
:文本的最小長度,默認爲Integer.MIN_VALUE
max
:文本的最大長度,默認爲Integer.MAX_VALUE
trim
:是否須要先作trim
操做,默認爲false
@Max
限制輸入內容的最大值,輸入內容會被強轉爲Integer
類型,若輸入文字不符合Integer
類型,會報ConversionException
異常。
TextView
value
:int
類型,最大值。@Min
限制輸入內容的最小值,輸入內容會被強轉爲Integer
類型,若輸入文字不符合Integer
類型,會報ConversionException
異常。
TextView
value
:int
類型,最小值。@NotEmpty
判斷輸入內容是否非空。
TextView
trim
:判斷以前是否要先trim
,默認爲false
emptyText
:設置「空字符串」,可自定義一段文本,當輸入此文本是則爲空emptyTextResId
:設置「空字符串」的資源文件@Order
肯定校驗字段的順序。當一個容器有多個View
須要檢驗時,可經過該註解肯定校驗順序。
TextView
CheckBox
RadioButton
RadioGroup
Spinner
value
:int
類型,用於肯定順序@Password
用於校驗文本是否符合密碼的規則。
TextView
min
:最小字符數,默認爲6scheme
:Scheme
類型,利用正則肯定密碼的輸入格式,只能爲Scheme
類型,不可自定義,默認爲Password.Scheme.ANY
Password.Scheme.ANY
:.+
Password.Scheme.ALPHA
:\w+
Password.Scheme.ALPHA_MIXED_CASE
:(?=.*[a-z])(?=.*[A-Z]).+
Password.Scheme.NUMERIC
:\d+
Password.Scheme.ALPHA_NUMERIC
:(?=.*[a-zA-Z])(?=.*[\d]).+
Password.Scheme.ALPHA_NUMERIC_MIXED_CASE
:(?=.*[a-z])(?=.*[A-Z])(?=.*[\d]).+
Password.Scheme.ALPHA_NUMERIC_SYMBOLS
:(?=.*[a-zA-Z])(?=.*[\d])(?=.*([^\w])).+
Password.Scheme.ALPHA_NUMERIC_MIXED_CASE_SYMBOLS
:(?=.*[a-z])(?=.*[A-Z])(?=.*[\d])(?=.*([^\w])).+
@Past
判斷輸入的時間是不是過去時間(與當前時間相比)。輸入的時間必須知足相應的格式。
TextView
dateFormat
:時間的格式,默認爲dd-MM-yyyy
,如下爲saripaar
提供的格式(可自定義)
DateFormats.DMY
:dd-MM-yyyy
DateFormats.YMD
:yyyy-MM-dd
DateFormats.MDY
:MM-dd-yyyy
DateFormats.DMY_TIME_12_HOURS
:dd-MM-yyyy hh:mm aa
DateFormats.YMD_TIME_12_HOURS
:yyyy-MM-dd hh:mm aa
DateFormats.MDY_TIME_12_HOURS
:MM-dd-yyyy hh:mm aa
DateFormats.DMY_TIME_24_HOURS
:dd-MM-yyyy kk:mm
DateFormats.YMD_TIME_24_HOURS
:yyyy-MM-dd kk:mm
DateFormats.MDY_TIME_24_HOURS
:MM-dd-yyyy kk:mm
dateFormatResId
:時間格式的資源ID@Pattern
判斷輸入的內容是否知足正則表達式。
TextView
regex
:正則表達式caseSensitive
:是否區分大小寫@Select
判斷選擇的索引是否等於默認值,若是不等於則經過,默認值爲0。
Spinner
defaultSelection
:設置默認值@Url
判斷輸入的內容是不是一個url
。
TextView
schemes
:是一個數組,url
的協議數組,可自定義,默認爲{"http", "https", "ftp"}
allowFragments
:url
片斷是否容許經過,默認爲true
@Optional
和@Or
雖然該版本已經有了這兩個註解,可是並不能使用,參考做者在stackoverflow
上的回覆,註解將會在2.1.0
版本上線
本篇文章簡單介紹了Android Saripaar
的用法,並着重列舉了各個註解的做用以及各個參數的意思,方便之後的查詢。
經過閱讀源碼對saripaar
有了更深的認識,並對基於註解的框架有了一個完備的認知。
之後若是有時間的話總結一下Android Saripaar
實現的細節。