用CSS怎样实现表单验证
发布时间:2024-04-27 18:37:06 所属栏目:编程 来源:DaWei
导读: 这篇文章给大家分享的是用CSS怎样实现表单验证的方法。在实际的项目中,表单验证是个很常见的需求,例如登录注册这些都会使用到表单验证。这里我们主要看如何纯CSS实现,文中的示例代码介绍
这篇文章给大家分享的是用CSS怎样实现表单验证的方法。在实际的项目中,表单验证是个很常见的需求,例如登录注册这些都会使用到表单验证。这里我们主要看如何纯CSS实现,文中的示例代码介绍得很详细,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。 表单验证一般我们的实现思路都是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> <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> 使用到的知识点 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 关于用CSS怎样实现表单验证就介绍到这,上述示例具有一定的借鉴价值,感兴趣的朋友可以参考。 (编辑:草根网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |