.

好程式設計師web前端教程分享JavaScript驗證API,小編每天會分享一下乾貨給大家。那麼今天說道的就是web前端培訓課程中的章節。

 

JavaScript驗證API

 

  約束驗證DOM方法

 

PropertyDescription

 

checkValidity()如果 input 元素中的資料是合法的返回 true,否則返回 false。

 

setCustomValidity()設定 input 元素的 validationMessage 屬性,用於自定義錯誤提示資訊的方法。

 

使用 setCustomValidity 設定了自定義提示後,validity.customError 就會變成true,則 checkValidity 總是會返回false。如果要重新判斷需要取消自定義提示,方式如下:

 

setCustomValidity('')

 

setCustomValidity(null)

 

setCustomValidity(undefined)

 

以下例項如果輸入資訊不合法,則返回錯誤資訊:

 

checkValidity() 方法

 

<input id="id1" type="number" min="100" max="300" required> <button onclick="myFunction()">驗證</button> <p id="demo"></p> <script>

 

function myFunction() { var inpObj = document.getElementById("id1"); if (inpObj.checkValidity() == false) { document.getElementById("demo").innerHTML = inpObj.validationMessage; } }

 

</script>

嘗試一下 »

約束驗證 DOM 屬性

屬性描述

validity布林屬性值,返回 input 輸入值是否合法

 

validationMessage瀏覽器錯誤提示資訊

 

willValidate指定 input 是否需要驗證

Validity 屬性

input 元素的 validity 屬性包含一系列關於 validity 資料屬性:

 

屬性描述

 

customError設定為 true, 如果設定了自定義的 validity 資訊。

 

patternMismatch設定為 true, 如果元素的值不匹配它的模式屬性。

 

rangeOverflow設定為 true, 如果元素的值大於設定的最大值。

 

rangeUnderflow設定為 true, 如果元素的值小於它的最小值。

 

stepMismatch設定為 true, 如果元素的值不是按照規定的 step 屬性設定。

 

tooLong設定為 true, 如果元素的值超過了 maxLength 屬性設定的長度。

 

typeMismatch設定為 true, 如果元素的值不是預期相匹配的型別。

 

valueMissing設定為 true,如果元素 (required 屬性) 沒有值。

 

valid設定為 true,如果元素的值是合法的。

 

例項

 

如果輸入的值大於 100,顯示一個資訊:

rangeOverflow 屬性

<input id="id1" type="number" min="100" required> <button onclick="myFunction()">OK</button> <p id="demo"></p> <script>

 

function myFunction() { var txt = ""; var inpObj = document.getElementById("id1"); if(!isNumeric(inpObj.value)) { txt = "你輸入的不是數字"; } else if (inpObj.validity.rangeUnderflow) { txt = "輸入的值太小了"; } else { txt = "輸入正確"; } document.getElementById("demo").innerHTML = txt; } // 判斷輸入是否為數字 function isNumeric(n) { return !isNaN(parseFloat(n)) && isFinite(n); }

 

</script>

<input id="id1" type="number" max="100"> <button onclick="myFunction()">驗證</button> <p id="demo"></p> <script>

 

function myFunction() { var txt = ""; if (document.getElementById("id1").validity.rangeOverflow) { txt = "輸入的值太大了"; } document.getElementById("demo").innerHTML = txt; }

 

</script>

嘗試一下 »

如果輸入的值小於 100,顯示一個資訊:

rangeUnderflow 屬性

嘗試一下 »

JavaScript 表單驗證

JavaScript 保留關鍵字

1 篇筆記

setCustomValidity 的用法:

 

var inpObj = document.getElementById("id1");

 

inpObj.setCustomValidity(''); // 取消自定義提示的方式

 

if (inpObj.checkValidity() == false) {

 

if(inpObj.value==""){

 

inpObj.setCustomValidity("不能為空!");

 

}else if(inpObj.value<100 || inpObj.value>300){

 

inpObj.setCustomValidity("請重新輸入數值(100~300之間)!");

 

}

 

document.getElementById("demo").innerHTML = inpObj.validationMessage;

 

} else {

 

document.getElementById("demo").innerHTML = "輸入正確";

 

}