搜尋
首頁web前端H5教程詳解HTML5中表單驗證的8種方法介紹

在深人探討表單驗證之前,讓我們先思考一下表單驗證的真實意義。就其核心而言,表單驗證是一套系統,它為終端用戶檢測無效的控制項資料並標記這些錯誤。換言之,表單驗證就是在表單提交伺服器前對其進行一系列的檢查並通知使用者修正錯誤。
但是真正的表單驗證是什麼?
是一種最佳化。
之所以說表單驗證是一種最佳化,是因為僅透過表單驗證機制不足以保證提交給伺服器的表單資料是正確且有效的。另一方面,設計表單驗證是為了讓Web應 用更快地拋出錯誤。換句話說,最好利用瀏覽器內建的處理機制來告知使用者網頁內包含無效的表單控制項值。過去,資料在網路上轉一圈,只是為了讓伺服器通知用 戶他輸入了錯誤的資料。如果瀏覽器完全有能力讓錯誤在離開客戶端之前就被捕獲到,那麼我們應該利用這個優勢。
不過,瀏覽器的表單檢查還不足以處理所有的錯誤。
話雖如此,HTML5還是引進了八種用於驗證表單控制項的資料正確性的方法。讓我們依序了解一下,不過先要介紹一下用於回饋驗證狀態的ValidityState物件。
在支援Html5表單驗證的瀏覽器中,可以透過表單控制項來存取ValidityState物件:

var valCheck = document.myForm.myInput.validity;

這行程式碼取得了名為myInput的表單元素的ValidityState物件。物件包含了對所有八種驗證狀態的引用,以及最終驗證結果。
呼叫方式如下:

valCheck.valid

執行完畢,我們會得到一個布林值,它表示表單控制項是否已通過了所有的驗證限制條件。可以把valid特性看做是最終驗證結果:如果所有八個約束條件都通過了,valid特性就是true,否則,只要有一項約束沒通過,valid標誌都是false。
如前所述,任何表單元素都有八個可能的驗證約束條件。每個條件在ValidityState物件中都有對應的特性名,可以用適當的方式存取。讓我們逐一分析,看看它們是如何與表單控制項關聯的,以及如何基於ValidityState物件來對它們進行檢查:
1、valueMissing
目的:確保表單控制項中的值已填寫。
用法:在表單控制項中將required特性設為true。
範例:

<input type="text" name="myText" required>

詳細說明:如果表單控制項設定了required特性,那麼在使用者填寫或透過程式碼呼叫方式填入值之前,控制項會一直處於無效狀態。例如,空的文字輸入框無法通過必填檢查,除非在其中輸入任意文字。輸入值為空時,valueMissing會回傳true。
2、typeMismatch
目的:保證控制項值與預期類型相符(如numbe、email、URL等).
用法:指定表單控制項的type特性值。
範例:

<input type="email" name="myEmail">

詳細說明:特殊的表單控制類型不只是用來定製手機鍵盤, 如果瀏覽器能夠識別出來表單控制項中的輸入不符合對應的類型規則,例如email位址中沒有@符號,或number型控制項的輸入值不是有效的數字,那麼瀏覽器就會把這個控制項標記出來以提示類型不符。無論哪種出錯情況,typeMismatch將傳回true。
3、patternMismatch
目的:根據表單控制項上設定的格式規則驗證輸入是否為有效格式。
用法:在表單控制項上設定pattern特性,井賦予適當的符合規則。
範例:

<input type="text" name="creditcardnumber" pattern="[0-9]{16}" title="A credit
card number is 16 digits with no spaces or dashes">

詳細說明:pattern特性向開發人員提供了一種強大且靈活的方式來為表單的控制項值設定正規表示式驗證機制。當為控制項設定了pattern特性後,只要 輸入控制項的值不符合模式規則,patternMismatch就會傳回true值。從引導使用者和技術參考兩方面考慮,你應該在包含pattern特性的表格 單一控制項中設定title特性以說明規則的作用。
4、tooLong
目的:避免輸入值包含過多字元。
用法:在表單控制項上設定maxLength特性。
範例:

<input type="text" name="limitedText" maxLength="140">

詳細說明:如果輸入值的長度超過maxLength, tooLong特性會回傳true。雖然表單控制項通常會在使用者輸入時限制最大長度,但在某些情況下,如透過程式設置,還是會超出最大值。
5、rangeUnderflow
目的:限制數值型控制項的最小值。
用法:為表單控制項設定min特性,並賦予允許的最小值。
範例:

<input type="range" name="ageCheck" min="18">

詳細說明:在需要做數值範圍檢查的表單控制項中,數值很可能會暫時低於設定的下限。此時,ValidityState的rangeUnderflow特性將會回傳true。
6、rangeOverflow
目的:限制數值型控制項的最大值。
用法:為表單控制項設定max特性,並賦予允許的最大值。
範例:

<input type="range" name="kidAgeCheck" max="12">

详细说明:与rangeUnderflow类似,如果一个表单控件的值比max更大,特性将返回true。
7、stepMismatch
目的:确保输入值符合min、max及step即设置。
用法:为表单控件设置step特性,指定数值的增量。
示例:

<input type="range" name="confidenceLevel" min="0" max="100" step="5">

详细说明:此约束条件用来保证数值符合min、max和step的要求。换句话说,当前值必须是最小值与step特性值的倍数之和。例如,范围从0到100,step特性值为5,此时就不允许出现17,否则stepMismatch返回true值。
8、customError
目的:处理应用代码明确设置及计算产生的错误。
用法:调用setCustomValidity(message)将表单控件置于customError状态。
示例:

passwordConfirmationField.setCustomValidity("Password values do not match.");

详细说明:浏览器内置的验证机制不适用时,需要显示自定义验证错误信息。当输入值不符合语义规则时,应用程序代码应设置这些自定义验证消息。
自定义验证消息的典型用例是验证控件中的值是否一致。例如,密码和密码确认两个输人框的值不匹配。只要定制了验证消息,控件就会处于无效状态,并且customError返回true。要清除错误,只需在控件上调用setCustomValidity("")即可。

以上就是详解HTML5中表单验证的8种方法介绍 的内容,更多相关内容请关注PHP中文网(www.php.cn)!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
html5的div一行可以放两个吗html5的div一行可以放两个吗Apr 25, 2022 pm 05:32 PM

html5的div元素默认一行不可以放两个。div是一个块级元素,一个元素会独占一行,两个div默认无法在同一行显示;但可以通过给div元素添加“display:inline;”样式,将其转为行内元素,就可以实现多个div在同一行显示了。

html5中列表和表格的区别是什么html5中列表和表格的区别是什么Apr 28, 2022 pm 01:58 PM

html5中列表和表格的区别:1、表格主要是用于显示数据的,而列表主要是用于给数据进行布局;2、表格是使用table标签配合tr、td、th等标签进行定义的,列表是利用li标签配合ol、ul等标签进行定义的。

html5怎么让头和尾固定不动html5怎么让头和尾固定不动Apr 25, 2022 pm 02:30 PM

固定方法:1、使用header标签定义文档头部内容,并添加“position:fixed;top:0;”样式让其固定不动;2、使用footer标签定义尾部内容,并添加“position: fixed;bottom: 0;”样式让其固定不动。

html5中不支持的标签有哪些html5中不支持的标签有哪些Mar 17, 2022 pm 05:43 PM

html5中不支持的标签有:1、acronym,用于定义首字母缩写,可用abbr替代;2、basefont,可利用css样式替代;3、applet,可用object替代;4、dir,定义目录列表,可用ul替代;5、big,定义大号文本等等。

HTML5中画布标签是什么HTML5中画布标签是什么May 18, 2022 pm 04:55 PM

HTML5中画布标签是“<canvas>”。canvas标签用于图形的绘制,它只是一个矩形的图形容器,绘制图形必须通过脚本(通常是JavaScript)来完成;开发者可利用多种js方法来在canvas中绘制路径、盒、圆、字符以及添加图像等。

html5废弃了哪个列表标签html5废弃了哪个列表标签Jun 01, 2022 pm 06:32 PM

html5废弃了dir列表标签。dir标签被用来定义目录列表,一般和li标签配合使用,在dir标签对中通过li标签来设置列表项,语法“<dir><li>列表项值</li>...</dir>”。HTML5已经不支持dir,可使用ul标签取代。

Html5怎么取消td边框Html5怎么取消td边框May 18, 2022 pm 06:57 PM

3种取消方法:1、给td元素添加“border:none”无边框样式即可,语法“td{border:none}”。2、给td元素添加“border:0”样式,语法“td{border:0;}”,将td边框的宽度设置为0即可。3、给td元素添加“border:transparent”样式,语法“td{border:transparent;}”,将td边框的颜色设置为透明即可。

html5为什么只需要写doctypehtml5为什么只需要写doctypeJun 07, 2022 pm 05:15 PM

因为html5不基于SGML(标准通用置标语言),不需要对DTD进行引用,但是需要doctype来规范浏览器的行为,也即按照正常的方式来运行,因此html5只需要写doctype即可。“!DOCTYPE”是一种标准通用标记语言的文档类型声明,用于告诉浏览器编写页面所用的标记的版本。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
2 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
2 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。