API de Validación de JavaScript
- Página anterior API Almacenamiento
- Página siguiente API Web
Métodos y propiedades de validación de DOM.
Método
Método | 描述 |
---|---|
checkValidity() | Retorna true si el elemento input contiene datos válidos. |
setCustomValidity() | Establece la propiedad validationMessage del elemento input. |
属性
属性 | 描述 |
---|---|
validity | Contiene las propiedades booleanas relacionadas con la validez del elemento input. |
validationMessage | Contiene el mensaje que el navegador mostrará cuando la validez sea falsa. |
willValidate | Indica si se validará el elemento input. |
Ejemplo - método checkValidity()
Si el campo de entrada contiene datos no válidos, se mostrará un mensaje:
<input id="id1" type="number" min="100" max="300" required> <button onclick="myFunction()">ACEPTAR</button> <p id="demo"></p> <script> function myFunction() { const inpObj = document.getElementById("id1"); if (!inpObj.checkValidity()) { document.getElementById("demo").innerHTML = inpObj.validationMessage; } } </script>
有效性属性
input 元素的有效性属性包含许多与数据有效性相关的属性:
属性 | 描述 |
---|---|
customError | 如果设置了自定义的有效性消息,则设置为 true。 |
patternMismatch | 如果元素的值与其 pattern 属性不匹配,则设置为 true。 |
rangeOverflow | 如果元素的值大于其 max 属性,则设置为 true。 |
rangeUnderflow | 如果元素的值小于其 min 属性,则设置为 true。 |
stepMismatch | 如果元素的值根据其 step 属性无效,则设置为 true。 |
tooLong | 如果元素的值超过其 maxLength 属性,则设置为 true。 |
typeMismatch | 如果元素的值根据其 type 属性无效,则设置为 true。 |
valueMissing | 如果元素(带有 required 属性)没有值,则设置为 true。 |
valid | 如果元素的值有效,则设置为 true。 |
实例
rangeOverflow 属性
如果 input 字段中的数字大于 100(input 的 max
属性),则显示一条消息:
<input id="id1" type="number" max="100"> <button onclick="myFunction()">ACEPTAR</button> <p id="demo"></p> <script> function myFunction() { let text = "Valor OK"; if (document.getElementById("id1").validity.rangeOverflow) { text = "Valor demasiado grande"; } } </script>
rangeUnderflow 属性
如果 input 字段中的数字大于 100(input 的 max
属性),则显示一条消息:
<input id="id1" type="number" min="100"> <button onclick="myFunction()">ACEPTAR</button> <p id="demo"></p> <script> function myFunction() { let text = "Valor OK"; if (document.getElementById("id1").validity.rangeUnderflow) { text = "Valor demasiado pequeño"; } } </script>
- Página anterior API Almacenamiento
- Página siguiente API Web