HTML5對表單元素提供了patern屬性,它接受一個正則表達(dá)式。表單提交時這個正則表達(dá)式會被用于驗證表單內(nèi)非空的值,如果控件的值不匹配這個正則表達(dá)就會彈出提示框,并阻止表達(dá)提交。提示框內(nèi)的文字可以使用setCustomValidity方法來自定義。
比如下面這個表單內(nèi),文本框只接受大陸的手機(jī)號,輸入其它東西就無法提交
運行
XML/HTML Code復(fù)制內(nèi)容到剪貼板
- <!DOCTYPE html>
- <form>
- <input id="text" pattern="^1[3-9]\d{9}$" required />
- <input id="button" type="submit" />
- </form>
注意只有非空的表單才會使用正則驗證,如果什么都不輸入的話,pattern不會被使用,所以還需要required協(xié)助。但是這個代碼彈出的提示是這樣的:
XML/HTML Code復(fù)制內(nèi)容到剪貼板
- <!DOCTYPE html>
- <form>
- <input id="text" pattern="^1[3-9]\d{9}$" required />
- <input id="button" type="submit" />
- </form>
- <script>
- text.oninput=function(){
- text.setCustomValidity("");
- };
- text.oninvalid=function(){
- text.setCustomValidity("請不要輸入火星的手機(jī)號好嗎?");
- };
- </script>
invalid事件會在表單submit事件之前觸發(fā),如果驗證不通過的話就不會觸發(fā)表單的submit。而提交時會先驗證所有表單元素是值是否有效。除了提交外還可以手動調(diào)用checkValidity方法來執(zhí)行驗證。
上面的例子中我直接對控件設(shè)置固定的提示其實不太好,有時候可能需要更詳細(xì)的提示信息,比如空的時候提示為空、太長的時候提示太長、非數(shù)字的時候提示非數(shù)字等。這些動作可以通過程序驗證后動態(tài)地setCustomValidity來實現(xiàn)。
其實我覺得HTML5的這套API設(shè)計的很糟糕,雖然可以滿足基本需求,但還真不太實用。
XML/HTML Code復(fù)制內(nèi)容到剪貼板
- <input id="name" name="name" placeholder="name" required="" tabindex="1" type="text">
- <input id="email" name="email" placeholder="telephone" required="" tabindex="2" type="text" pattern="(^(\d{3,4}-)?\d{7,8})$|^(13|15|18|14)\d{9}$">
- <input id="subject" name="subject" placeholder="example@domain.com" required="" tabindex="2" type="text">
- // 主要用了HTML的一下屬性
- // 1.placeholder 提供可描述輸入字段預(yù)期值的提示信息。 該提示會在輸入字段為空時顯示,并會在字段獲
- //得焦點時消失
- //2.required 屬性規(guī)定必需在提交之前填寫輸入字段
- //3.pattern 是正則表達(dá)式, 里面可以直接填寫正則表達(dá)式