HTML5 自定義驗證資訊顯示方式
HTML5內建表單驗證功能,在某種程度上提高了開發效率。
比如要求某個文字框是必填的,只要為其新增required屬性即可。
如果要求內容必須是郵箱格式,只需將input的type屬性值設定為"email"即可。
比使用JavaScript寫驗證規則要方便的多,開發效率上當然也會得到極大提高。
有利必然有弊,雖然驗證非常高效,但是驗證提示資訊和資訊顯示方式過於固定,有事難以滿足專案需求。
當然,HTML5提供瞭解決上述問題的方法,自定義驗證提示資訊參閱setCustomValidity()自定義驗證資訊一文。
本文再來通過程式碼例項介紹一下如何自定義驗證資訊的顯示方式,而不是隻能通過彈出框的形式。
首先看一段程式碼例項:
[HTML] 純文字檢視 複製程式碼執行程式碼<!doctype html> <html> <head> <meta charset="utf-8"> <meta name="author" content="http://www.softwhy.com/" /> <title>螞蟻部落</title> <style> body{margin:50px;} </style> </head> <body> <form action="http://www.softwhy.com/"> <input type="text" id="num" required pattern="^\d{3,8}$"/> <br/><br/> <input type="submit" id="bt" value="提交表單"> </form> </body> </html>
上述程式碼如果為空,或者填寫內容不符合pattern屬性固定的格式就會報錯。
程式碼執行效果截圖如下:
報錯方式預設都是以上述類似提示框的方式展現,這是一個硬傷。
因為這樣的顯示方式很難滿足頁面多樣性的需求,難以做到對於任何頁面都完美適配。
如果僅僅是這樣,那麼HTML5內建的表單驗證功能確實有點雞肋,事實上我們可以實現自定義。
看如下程式碼例項如下:
[HTML] 純文字檢視 複製程式碼執行程式碼<!doctype html> <html> <head> <meta charset="utf-8"> <meta name="author" content="http://www.softwhy.com/" /> <title>螞蟻部落</title> <style> body{margin:50px;} #error{ display:none; color:red; } </style> <script> window.onload=function(){ let num=document.getElementById("num"); let obt=document.getElementById("bt"); let error=document.getElementById("error"); num.oninvalid=function(){ let v=num.validity; if(true === v.valueMissing){ error.style.display="inline-block"; error.innerHTML="欄位不能為空"; num.focus(); return false; }else if(true === v.patternMismatch){ error.style.display="inline-block"; error.innerHTML="請輸入3-8位數字"; num.focus(); return false; } } } </script> </head> <body> <form action="http://www.softwhy.com/"> <input type="text" id="num" required pattern="^\d{3,8}$"/> <span id="error">郵箱不能為空</span> <br/> <input type="submit" id="bt" value="提交表單"> </form> </body> </html>
上述程式碼實現了我們自定義驗證資訊顯示方式的要求,下面對其實現方式進行簡單介紹。
(1).內建表單驗證規則沒有沒有被滿足的時候,點選表單提交按鈕會觸發invalid事件。
(2).利用表單元素的validity屬性獲取其當前表單驗證狀態資訊。
(3).然後利用這些表單驗證狀態資訊定製相應的規則,上述程式碼將驗證資訊顯示於文字框的右側。
(4).有一點特別重要,那就是事件處理函式中的return false語句,它可以阻止瀏覽器預設行為,也就是阻止預設狀態下以彈出框形式給予驗證資訊的行為。
相關文章
- HTML5 setCustomValidity()自定義驗證資訊HTML
- HTML5 setCustomValidity() 自定義驗證資訊HTML
- HTML5 pattern自定義驗證規則HTML
- mongoose使用validate驗證, 獲取自定義驗證資訊Go
- 顯示驗證的錯誤資訊
- jQuery Validate自定義驗證錯誤資訊jQuery
- jQuery Validate自定義錯誤資訊顯示位置jQuery
- Laravel 自定義表單驗證-自定義驗證規則Laravel
- 自定義react資料驗證元件React元件
- Jwtauth 自定義認證頭資訊JWT
- SpringBoot-表單驗證-統一異常處理-自定義驗證資訊源Spring Boot
- MUI DtPicker 顯示自定義日期UI
- [BUG反饋]自定義模型不顯示資料模型
- Laravel 自定義配置資訊的儲存方式Laravel
- Layui 自定義表單驗證UI
- 如何自定義終端顯示配置
- Android自定義View---驗證碼AndroidView
- thinkphp驗證器獲取$data資料,自定義驗證,多條件唯一性驗證unique驗證PHP
- jQuery Validate新增自定義驗證規則jQuery
- 表單驗證自定義格式輸出
- gin自定義驗證器&轉化中文
- gRPC(七)進階:自定義身份驗證RPC
- 簡訊驗證實現方式
- Laravel 自定義表單請求驗證忽略某些欄位驗證Laravel
- Android自定義方形驗證碼輸入框Android
- Laravel 自定義驗證規則的問題Laravel
- vue自定義指令擷取圖片中心顯示Vue
- Django Admin自定義app中模型顯示順序DjangoAPP模型
- 如何設定 GNOME 顯示自定義幻燈片
- 如何使用JSR303驗證及自定義訊息統一處理JS
- 使用 GoFrame 框架 JWT 方式驗證使用者資訊GoFrame框架JWT
- c#自定義型別的轉換方式operator,以及implicit(隱式)和explicit (顯示)宣告C#型別
- PbootCMS驗證碼不顯示怎麼辦boot
- 驗證裡,PHP 檔案中指定自定義值PHP
- java使用sshd 實現sftp 自定義顯示目錄JavaFTP
- Mac自定義觸控欄 Touch Bar的顯示教程Mac
- 6. 自定義容器型別元素驗證,類級別驗證(多欄位聯合驗證)型別
- UEditor 自定義圖片視訊尺寸校驗