前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >纯CSS实现表单验证

纯CSS实现表单验证

作者头像
陈大鱼头
发布2020-04-16 15:36:05
1.5K0
发布2020-04-16 15:36:05
举报
文章被收录于专栏:鱼头的Web海洋鱼头的Web海洋

  • 首发:krissarea.gitee.io (https://krissarea.gitee.io/blog/css/others/css-form-validation.html)
  • 作者:陈大鱼头 (https://juejin.im/user/576b433bd342d30057aaa1e9/posts)
  • github: KRISACHAN (https://github.com/KRISACHAN)

关于表单验证

在我们的日常业务中,表单验证是个很常见设计需求,像一些登录注册框,问卷调查也都需要用到表单验证。

一般我们的实现思路都是JS监听input框的输入内容,判断用户输入内容,从而以此来决定下一步的操作。

例如这样:(以下例子来自优秀的开源UI库,element)

代码语言:javascript
复制
  1. <el-form :model="numberValidateForm" ref="numberValidateForm" label-width="100px" class="demo-ruleForm">
  2. <el-form-item
  3. label="年龄"
  4. prop="age"
  5. :rules="[
  6. { required: true, message: '年龄不能为空'},
  7. { type: 'number', message: '年龄必须为数字值'}
  8. ]"
  9. >
  10. <el-input type="age" v-model.number="numberValidateForm.age" autocomplete="off"></el-input>
  11. </el-form-item>
  12. <el-form-item>
  13. <el-button type="primary" @click="submitForm('numberValidateForm')">提交</el-button>
  14. <el-button @click="resetForm('numberValidateForm')">重置</el-button>
  15. </el-form-item>
  16. </el-form>
  17. <script>
  18. export default {
  19. data() {
  20. return {
  21. numberValidateForm: {
  22. age: ''
  23. }
  24. };
  25. },
  26. methods: {
  27. submitForm(formName) {
  28. this.$refs[formName].validate((valid) => {
  29. if (valid) {
  30. alert('submit!');
  31. } else {
  32. console.log('error submit!!');
  33. return false;
  34. }
  35. });
  36. },
  37. resetForm(formName) {
  38. this.$refs[formName].resetFields();
  39. }
  40. }
  41. }
  42. </script>

以上就是我们常规的表达验证了,基本就都是用JS来完成的,那么我们能不能用CSS来实现呢?答案是可以的。这里先上DEMO (https://krisachan.github.io/css/css-form-validation.html)

CSS实现表单验证

上面的表单验证就完全是由CSS来实现的,核心属性就是 CSSLevel4Validity。思路就是利用 :valid:invalid可以对 <input>value进行判断的特性。

这里是全部代码

代码语言:javascript
复制
  1. /*
  2. * css
  3. */
  4. :root {
  5. --error-color: red;
  6. }
  7. .form > input {
  8. margin-bottom: 10px;
  9. }
  10. .form > .f-tips {
  11. color: var(--error-color);
  12. display: none;
  13. }
  14. input[type="text"]:invalid ~ input[type="submit"],
  15. input[type="password"]:invalid ~ input[type="submit"] {
  16. display: none;
  17. }
  18. input[required]:invalid + span {
  19. display: inline;
  20. }
  21. /*
  22. * html
  23. */
  24. <form class="form" id="form" method="get" action="/api/form">
  25. 账号:
  26. <input data-title="账号" pattern="[\w]{6,10}" name="account" type="text" required />
  27. <span class="f-tips">请输入正确的账号</span>
  28. <br />
  29. 密码:
  30. <input data-title="密码" pattern="[\w]{6,10}" name="password" type="password" required />
  31. <span class="f-tips">请输入正确的密码</span>
  32. <br />
  33. <input name="button" type="submit" value="提交" />
  34. </form>

效果截图

使用到的知识点

1. HTML5<input>的新属性: pattern

MDN的解释:

检查控件值的正则表达式.。pattern必须匹配整个值,而不仅仅是某些子集.。使用title属性来描述帮助用户的模式.。当类型属性的值为text, search, tel, url 或 email时,此属性适用,否则将被忽略。(兼容ie10+)

备注:

  1. 如果 pattern里的验证规则不合法,例如多了长度校验内多了空格,也是会在控制台报错的,详情如下:
代码语言:javascript
复制
  1. <input data-title="账号" pattern="/[\w]{6, 10}/" name="account" type="text" required />
  2. CSSJS里的验证规则不一样,以下写法是会无效的,核心校验规则需要用 []包起来(目前从测试的几个例子是这样,具体详情还需要翻查资料,如果有大佬知道更具体的信息,请告知,谢谢!)
代码语言:javascript
复制
  1. <input data-title="账号" pattern="/\w{6,10}/" name="account" type="text" required />
2. CSSLevel4选择器的新属性: invalid

详细介绍请看我的博文[译]19个CSS level 4 选择器(https://juejin.im/post/5c42c657e51d4551ec60c283)

如果你也喜欢 CSS,喜欢探讨技术,或者对本文,本系列有任何的意见或建议,鱼头非常希望你能加入一个有趣的微信群 — “进击的CSS”。如果你有兴趣,请添加鱼头微信(krisChans95),添加时注明 “加群”,Mmmm,最后,如果觉得我的文章还不错,请加个关注跟点个“好看”呗!

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-03-16,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 鱼头的Web海洋 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 关于表单验证
  • CSS实现表单验证
    • 这里是全部代码
      • 效果截图
        • 使用到的知识点
          • 1. HTML5里 <input>的新属性: pattern
          • 2. CSSLevel4选择器的新属性: invalid
      相关产品与服务
      腾讯问卷
      腾讯问卷是专业的在线问卷调查平台,支撑了腾讯核心业务的⽤户、市场、产品研究工作。平台提供基于数据收集的专业调查研究解决方案,覆盖问卷调查、信息上报、在线测评、在线考试、360度评估、投票打卡等工作场景,致力于为客户提供高效的洞察决策工具。同时平台还拥有超百万级的真实样本用户,可以提供高效、精准的问卷有偿投放服务。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档