带你走进JavaScript(三十)擅长的领域"/>
夜光带你走进JavaScript(三十)擅长的领域
夜光序言:
我遇见你,是最灿烂的花开,最美丽的意外。
正文:嗯唔,我们可以看下
数据验证
数据验证用于确保用户输入的数据是有效的。
典型的数据验证有:
- 必需字段是否有输入?
- 用户是否输入了合法的数据?
- 在数字字段是否输入了文本?
大多数情况下,数据验证用于确保用户正确输入数据。
数据验证可以使用不同方法来定义,并通过多种方式来调用。
服务端数据验证是在数据提交到服务器上后再验证。
客户端数据验证 side validation是在数据发送到服务器前,在浏览器上完成验证。
HTML 约束验证
HTML5 新增了 HTML 表单的验证方式:约束验证(constraint validation)。
约束验证是表单被提交时浏览器用来实现验证的一种算法。
HTML 约束验证基于:
- HTML 输入属性
- CSS 伪类选择器
- DOM 属性和方法
约束验证 HTML 输入属性:一些参数
属性 | 描述 |
---|---|
disabled | 规定输入的元素不可用 |
max | 规定输入元素的最大值 |
min | 规定输入元素的最小值 |
pattern | 规定输入元素值的模式 |
required | 规定输入元素字段是必需的 |
type | 规定输入元素的类型 |
约束验证 CSS 伪类选择器
选择器 | 描述 |
---|---|
:disabled | 选取属性为 "disabled" 属性的 input 元素 |
:invalid | 选取无效的 input 元素 |
:optional | 选择没有"required"属性的 input 元素 |
:required | 选择有"required"属性的 input 元素 |
:valid | 选取有效值的 input 元素 |
οnsubmit="return validateForm()" 为什么不是 οnsubmit="validateForm()"呢
οnsubmit="validateForm()" 能够调用 validateForm() 对表单进行验证,但是在验证不通过的情况下,并不能阻止表单提交。
οnsubmit="return validateForm()" 当验证不通过时,返回 false,可以阻止表单提交。
为什么呢
原来 onsubmit 属性就像是 <form> 这个 html 对象的一个方法名,其值(一字符串)就是其方法体,默认返回 true;
onsubmit="return validateForm()"
相当于:
Form.prototype.onsubmit = function() {return validateForm()
};
这样复写了 onsubmit 的默认方法(默认返回 true),根据 validateForm() 的结果返回 true 或 false,当验证不通过时,返回 false,οnsubmit="return false;" 阻止表单提交。
看一个很帅气的:JavaScript 验证 API
约束验证 DOM 方法
Property | Description |
---|---|
checkValidity() | 如果 input 元素中的数据是合法的返回 true,否则返回 false。 |
setCustomValidity() | 设置 input 元素的 validationMessage 属性,用于自定义错误提示信息的方法。 使用 setCustomValidity 设置了自定义提示后,validity.customError 就会变成true,则 checkValidity 总是会返回false。如果要重新判断需要取消自定义提示,方式如下: |
写一个例子,判断如果输入信息不合法,则返回错误信息:
checkValidity() 方法
<!DOCTYPE html>
<html>
<head><meta charset="utf-8">
</head>
<body><p>夜光 → 输入数字并点击验证按钮:</p><input id="id1" type="number" min="100" max="300" required>
<button onclick="myFunction()">验证</button><p>如果输入的数字小于 100 或大于300,会提示错误信息。</p><p id="demo"></p><script>function myFunction() {var inpObj = document.getElementById("id1");if (inpObj.checkValidity() == false) {document.getElementById("demo").innerHTML = inpObj.validationMessage;} else {document.getElementById("demo").innerHTML = "输入正确";}}
</script></body>
</html>
约束验证 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,显示一个信息:
<!DOCTYPE html>
<html>
<head><meta charset="utf-8">
</head>
<body><p>夜光:输入数字并点击验证按钮</p><input id="id1" type="number" max="100">
<button onclick="myFunction()">验证</button><p>如果输入的数字大于 100 ( input 的 max 属性), 会显示错误信息。</p><p id="demo"></p><script>function myFunction() {var txt = "";if (document.getElementById("id1").validity.rangeOverflow) {txt = "输入的值太大了";} else {txt = "输入正确";}document.getElementById("demo").innerHTML = txt;}
</script>
</body>
</html>
判断如果输入的值小于 100,显示一个信息:
rangeUnderflow 属性
<!DOCTYPE html>
<html>
<head><meta charset="utf-8">
</head>
<body><p>夜光:输入数字并点击验证按钮</p>
<input id="id1" type="number" min="100" required>
<button onclick="myFunction()">验证</button><p>如果输入的数字小于 100 ( input 的 min 属性), 会显示错误信息。</p><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></body>
</html>
更多推荐
夜光带你走进JavaScript(三十)擅长的领域
发布评论