html5表單驗證
問題描述
html5中那些原生的驗證,如required、pattern等,在驗證無效時,那些彈出的提示框是怎么實現(xiàn)的?為什么當(dāng)因為不同的約束條件不滿足而無效時,會彈出不同內(nèi)容的提示框?是不是結(jié)合invalid事件和validity屬性實現(xiàn)的?setCustomValidity()方法的工作原理是什么?感覺這塊內(nèi)容越看越亂,還請大牛指教……
問題解答
回答1:去看MDN上的表單驗證吧,我覺得說的還是挺清楚的,你可以按照它給的小demo一點點擼,慢慢就明白了。
回答2:required:空白驗證,比如說:
<form> <input type='text' required oninvalid='setCustomValidity(’此處不能為空!’)' oninput=(’setCustomValidity()’)> <input type='submit' value='提交'></form>
如果input[type=text]的value為空,就會彈出提示框,并且阻止表單提交;pattern:匹配正則表達(dá)式,比如說:
<form> <input type='text' pattern='[0-9]{3}' oninvalid='setCustomValidity(’請輸入3個數(shù)字!’)' oninput=(’setCustomValidity()’)> <input type='submit' value='提交'></form>
如若input[type=text]的value不為3個數(shù)字,在點擊提交按鈕的時候,就會提出提示
相關(guān)文章:
1. 輸入地址報以下截圖錯誤,怎么辦?2. 對于meta的使用3. thinkphp3 count()方法必須加上字段?4. python - 《flask web 開發(fā)》一書,數(shù)據(jù)庫中多對多關(guān)系的實現(xiàn)問題?5. 這是什么情況???6. node.js - nodejs中mysql子查詢返回多行結(jié)果怎么處理?7. mysql - 瞬間流量很高的網(wǎng)站,要頻繁的插入數(shù)據(jù)到數(shù)據(jù)庫,應(yīng)該怎么解決這個問題?8. mysql 5個left關(guān)鍵 然后再用搜索條件 幾千條數(shù)據(jù)就會卡,如何解決呢9. python中return 語句與 分支語句連用問題10. python - angular route 與 django urls 沖突怎么解決?
