- 作者:陈大鱼头
- github:KRISACHAN
关于表单验证
在我们的日常业务中,表单验证是个很常见设计需求,像一些登录注册框,问卷调查也都需要用到表单验证。
一般我们的实现思路都是 JS 监听 input 框的输入内容,判断用户输入内容,从而以此来决定下一步的操作。
例如这样:(以下例子来自优秀的开源 UI 库,element)
<el-form :model="numberValidateForm" ref="numberValidateForm" label-width="100px" class="demo-ruleForm">
<el-form-item
label="年龄"
prop="age"
:rules="[{ required: true, message: '年龄不能为空'},
{type: 'number', message: '年龄必须为数字值'}
]"
>
<el-input type="age" v-model.number="numberValidateForm.age" autocomplete="off"></el-input>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="submitForm('numberValidateForm')"> 提交 </el-button>
<el-button @click="resetForm('numberValidateForm')"> 重置 </el-button>
</el-form-item>
</el-form>
<script>
export default {data() {
return {
numberValidateForm: {age: ''}
};
},
methods: {submitForm(formName) {this.$refs[formName].validate((valid) => {if (valid) {alert('submit!');
} else {console.log('error submit!!');
return false;
}
});
},
resetForm(formName) {this.$refs[formName].resetFields();}
}
}
</script>
以上就是我们常规的表达验证了,基本就都是用 JS 来完成的,那么我们能不能用 CSS 来实现呢?答案是可以的。这里先上 DEMO
CSS 实现表单验证
上面的表单验证就完全是由 CSS 来实现的,核心属性就是 CSS Level 4
的Validity
。思路就是利用 :valid
跟:invalid
可以对 <input>
的value
进行判断的特性。
这里是全部代码
/*
* css
*/
:root {--error-color: red;}
.form > input {margin-bottom: 10px;}
.form > .f-tips {color: var(--error-color);
display: none;
}
input[type="text"]:invalid ~ input[type="submit"],
input[type="password"]:invalid ~ input[type="submit"] {display: none;}
input[required]:invalid + span {display: inline;}
/*
* html
*/
<form class="form" id="form" method="get" action="/api/form">
账号:<input data-title="账号" pattern="\w{6,10}" name="account" type="text" required />
<span class="f-tips"> 请输入正确的账号 </span>
密码:<input data-title="密码" pattern="\w{6,10}" name="password" type="password" required />
<span class="f-tips"> 请输入正确的密码 </span>
<input name="button" type="submit" value="提交" />
</form>
效果截图
使用到的知识点
1. HTML5
里 <input>
的新属性:pattern
MDN 的解释:
检查控件值的正则表达式.。pattern 必须匹配整个值,而不仅仅是某些子集.。使用 title 属性来描述帮助用户的模式.。当类型属性的值为 text, search, tel, url 或 email 时,此属性适用,否则将被忽略。(兼容 ie10+)
备注:
- 如果
pattern
里的验证规则不合法,例如多了长度校验内多了空格,也是会在控制台报错的,详情如下:
<input data-title="账号" pattern="/[\w]{6, 10}/" name="account" type="text" required />
-
CSS
与JS
里的验证规则不一样,以下写法是会无效的,核心校验规则需要用[]
包起来(目前从测试的几个例子是这样,具体详情还需要翻查资料,如果有大佬知道更具体的信息,请告知,谢谢!)
<input data-title="账号" pattern="/\w{6,10}/" name="account" type="text" required />
2. CSS Level 4 选择器
的新属性:invalid
详细介绍请看我的博文[[译]19 个 CSS level 4 选择器](https://juejin.im/post/5ce3b3…
如果你、喜欢探讨技术,或者对本文有任何的意见或建议,你可以扫描下方二维码,关注微信公众号“鱼头的 Web 海洋”,随时与鱼头互动。欢迎!衷心希望可以遇见你。