這篇文章主要介紹H5使用約束驗證API的方法,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
成都創(chuàng)新互聯(lián)公司是一家專業(yè)從事成都網(wǎng)站建設(shè)、成都網(wǎng)站設(shè)計的網(wǎng)絡(luò)公司。作為專業(yè)網(wǎng)站制作公司,成都創(chuàng)新互聯(lián)公司依托的技術(shù)實力、以及多年的網(wǎng)站運營經(jīng)驗,為您提供專業(yè)的成都網(wǎng)站建設(shè)、網(wǎng)絡(luò)營銷推廣及網(wǎng)站設(shè)計開發(fā)服務(wù)!
HTML5對于表單有著極大程度的優(yōu)化,無論是語義,小部件,還是數(shù)據(jù)格式的驗證。我猜你肯定會以瀏覽器兼容作為借口不愿意使用這些“新功能”,但這絕不應(yīng)該成為使你停滯不前的原因,況且還有像Modernizr和ployfill這樣的工具庫幫助你在不支持Html5的瀏覽器上進行回退處理。當你真正試著使用這些表單的新功能時,我保證你會愛上它。如果說唯一的缺陷,就是提示框的樣式是瀏覽器默認的,你無法改變,好吧,如果你相信瀏覽器廠商的設(shè)計師的審美水平的話(我相信他們的設(shè)計水平比絕大部分普通人要好,如果不考慮風(fēng)格兼容的話),抓緊學(xué)就對了!
原生驗證
input type
HTML5中為數(shù)據(jù)格式驗證提供了很多原生的支持,例如:
當點擊提交按鈕時,如果你輸入的格式不符合email,則會導(dǎo)致無法提交,瀏覽器會提示你錯誤信息。
比如在chrome下:
注意:
1、僅當你提交的時候會觸發(fā)瀏覽器的驗證
2、不同瀏覽器提示信息的行為樣式不一樣
3、當有多個input不符合要求時,只會提示一個錯誤,一般會提示表單中相對較前的Input的
不要理所應(yīng)當?shù)恼J為當input的type等于tel的時候,如果你輸入的不是電話號碼格式,在提交時也會被瀏覽器的阻擋并提示錯誤信息,type=’tel’在PC端只起到語義的作用,在移動端可以使產(chǎn)生的鍵盤為純數(shù)字鍵盤,并不能起到數(shù)據(jù)驗證的作用。
pattern
你可以使用pattern屬性來對瀏覽器不提供原生驗證的數(shù)據(jù)格式設(shè)置自定義格式驗證。pattern屬性的值是一個正則表達式(字符串):
點擊提交時,如果你輸入的數(shù)據(jù)不符合pattern里面正則的格式,那么瀏覽器會阻止表單提交,并提示:‘請與所請求的格式保持一致’+ title里的內(nèi)容(小字)。但注意,當你的文本框中內(nèi)容為空的時候,瀏覽器不會對其進行檢查,會直接提交表單(因為瀏覽器認為這個框框不是必填項)。如果你想要這個框框必須有內(nèi)容,請加上required屬性。
通過HTML原生的驗證系統(tǒng),基本就能滿足我們對表單提交的限定。但HTML5提供了更高級的功能來方便我們開發(fā)和提升用戶體驗。
約束驗證API
默認提示信息
像‘請與所請求的格式保持一致’這樣的瀏覽器提示信息字串藏在input DOM對象的validationMessage屬性里,這個屬性在大多數(shù)現(xiàn)代的瀏覽器中是只讀的,即不可修改,比如下面的代碼:
當提交時,如果Input內(nèi)容為空,那么瀏覽器會提示‘請?zhí)顚懘俗侄巍覀兛梢栽诳刂婆_把這句話打印出來:
var input = document.getElementById('input') input.validationMessage // =>'請?zhí)顚懘俗侄?#39;
如果想修改其中的內(nèi)容,可以調(diào)用setCustomValidity接口改變validationMessage的值
input.setCustomValidity('這個字段必須填上哦'); // 下面這種做法適用于不支持setCustomValidity的瀏覽器,基本現(xiàn)代瀏覽器都不支持這樣做 input.validationMessage = '這個字段必須填上哦'
注意,像required這樣的HTML原生驗證,雖然能改變其中信息,但無法把信息置為空字串,原因下面會講到。
原理
HTML表單驗證系統(tǒng)通過validationMessage屬性檢測該文本框的數(shù)據(jù)是否通過驗證,如果其值為空字串,則表示通過了驗證,否則,表示未通過,瀏覽器會把其值作為錯誤信息提示給用戶。所以在原生驗證時,用戶無法把validationMessage的值設(shè)置為空字符串。
約束驗證API的簡單實例
約束驗證API是在原生方法之上更靈活的表達方式,你可以自己設(shè)置數(shù)據(jù)是否通過,而不借助于正則表達式。原理很簡單,通過if判斷,如果數(shù)據(jù)格式使你滿意,那么你就調(diào)用setCustomValidity使validationMessage的值為空,否則,你就調(diào)用setCustomValidity傳入錯誤信息:
input.addEventListener('input', function () { if(this.value.length > 3){ // 判斷條件完全自定義 input.setCustomValidity('格式不正確'); }else { input.setCustomValidity('') } });
每次鍵盤輸入,代碼都會判斷格式是否正確,然后調(diào)用setCustomValidity設(shè)置validationMessage的值。不要妄想每按下鍵瀏覽器都會提示你結(jié)果是否正確,瀏覽器只有在點擊提交按鈕的時候才會提示validationMessage里的值(如果有的話)。
如果你還沒有走思的話,一定會問,既然這樣,為什么要為input綁定鍵盤事件,每輸入一下都要進行判斷呢?直接為表單綁定提交事件,在提交時再判斷多好,別急,這么做是有好處的。
隨著輸入判斷格式與樣式
作為用戶,我們當然想在得知我輸入了錯誤的格式之后,文本框變紅(或者有別的提示)。而在我每次輸入一個字符,如果對了,文本框就恢復(fù)正常。我們可以使用CSS偽類來實現(xiàn)這個功能:
input:required { background-color: #FFE14D; } /*這個偽類通過validationMessage屬性進行判斷*/ input:invalid { border: 2px solid red; }
上面的required偽類會給所以必填但值空的input提供一個黃色的背景色,而下面的invalid偽類則會為所有未通過驗證的input添加一個2px的紅邊邊。我們現(xiàn)在給我們的Input框加上input類即可。
這些偽類的判斷條件正與瀏覽器判斷你能否提交表單的條件一樣,看validationMessage里的值,所以,我們上面設(shè)置每次鍵盤輸入事件都會觸發(fā)一次判斷從而改變CSS偽類樣式的渲染,用意正在于此。
更好的用戶體驗
還有一個缺點,就是當一個input設(shè)置為required的時候,在初始化時,因為其本身是空的,所以invalid偽類會對它起作用,這不是我們想看到的,因為我們什么還都沒有干。
我們可以并在這些偽類前加上父選擇器.invalid,這樣,只有在父元素具有invalid類時,這些偽類才會起作用??梢栽O(shè)置一個submit事件,在表單提交因驗證失敗后,會觸發(fā)input的invalid事件,給form添加invalid類:
form.addEventListener('invalid', function() {this.className = 'invalid'}, true)因為invaild是Input的事件,而不是form的事件,所以這里我們設(shè)置第三個參數(shù)為true采用事件捕獲的方式處理之。這樣,就大功告成了。
最終實例
好了,現(xiàn)在是時候總結(jié)一下我們所學(xué)的知識并創(chuàng)造最佳實踐了:
form
運行后截圖如下:
以上是H5使用約束驗證API的方法的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!