Code前端首页关于Code前端联系我们

CSS实现表单验证:基本CSS属性4级验证

terry 2年前 (2023-09-27) 阅读数 76 #数据结构与算法

关于表单验证

在我们的日常业务中,表单验证是一个很常见的设计需求,比如一些登录注册框、问卷等也需要用到表单。确认。

总的来说,我们的实现思路是利用JS来监听输入域的输入内容,判断用户输入的内容,从而判断下一步的操作。

例如:(下面的例子来自于优秀的开源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来实现吗?答案是肯定的。这里我们首先使用DEMOCSS来实现表单验证

上面的表单验证完全是CSS实现的。基本属性为 CSS 级别 4 有效性。目标是用:valid:invalid来判断❙> 。

这里是全部代码

/*
 * 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>
复制代码

效果截图

CSS实现表单验证:核心属性CSS Level 4的ValidityCSS实现表单验证:核心属性CSS Level 4的Validity

用到的知识点

1。新属性 HTML5 检查值模式​​

来自 MDN 的说明: 来自 MDN 的说明: 该模式必须与整个值匹配,不仅仅是某个子集。使用标题属性来描述如何帮助用户。当属性类型的值为text、search、tel、url或email时使用该属性,否则将被忽略。 (兼容ie10+)

注意事项:

  1. 如果模式中的验证规则不合法,例如长度验证中空格太多,控制台会报错。具体如下:
CSS实现表单验证:核心属性CSS Level 4的Validity
<input data-title="账号" pattern="/[\w]{6, 10}/" name="account" type="text" required />
复制代码
  1. CSS中的验证规则与JS中的验证规则不同。以下注册方式无效。基本验证规则必须包含在 [] 中(当前来自多个测试)一个例子是这样的。您必须检查信息以了解具体细节。如果有人知道更具体的信息,请告诉我们,谢谢!)
<input data-title="账号" pattern="/\w{6,10}/" name="account" type="text" required />
复制代码

2. 新的CSS Level 4选择器属性inValid

详细介绍请看我的博文【翻译】19 CSS Level 4选择器

作者:陈大鱼头
来源:Nugety

版权声明

本文仅代表作者观点,不代表Code前端网立场。
本文系作者Code前端网发表,如需转载,请注明页面地址。

热门