在我们的日常业务中,表单验证是个很常见设计需求,像一些登录注册框,问卷调查也都需要用到表单验证。
一般我们的实现思路都是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 (https://krisachan.github.io/css/css-form-validation.html)
上面的表单验证就完全是由CSS来实现的,核心属性就是 CSSLevel4
的 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>
<br
/>
密码:
<input
data-title="密码"
pattern="[\w]{6,10}"
name="password"
type="password"
required
/>
<span
class="f-tips">请输入正确的密码</span>
<br
/>
<input
name="button"
type="submit"
value="提交"
/>
</form>
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
/>
CSSLevel4选择器
的新属性: invalid
详细介绍请看我的博文[译]19个CSS level 4 选择器(https://juejin.im/post/5c42c657e51d4551ec60c283)
如果你也喜欢 CSS
,喜欢探讨技术,或者对本文,本系列有任何的意见或建议,鱼头非常希望你能加入一个有趣的微信群 — “进击的CSS”。如果你有兴趣,请添加鱼头微信(krisChans95),添加时注明 “加群”,Mmmm,最后,如果觉得我的文章还不错,请加个关注跟点个“好看”呗!