加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 综合聚焦 > 编程要点 > 语言 > 正文

运用CSS怎样实现表单验证,需要注意哪些?

发布时间:2023-08-18 14:38:48 所属栏目:语言 来源:
导读: 这篇文章给大家分享的是用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
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章