element的form表单校验(身份证号、手机号、整数、汉字、for循环列表)

<template>
  <div class="FormPage">
    <el-form ref="form" :model="form" :rules="rules" label-width="100px">
      <el-form-item label="姓名:" prop="name">
        <el-input v-model="form.name" placeholder="请输入" maxlength="10" />
      </el-form-item>
      <el-form-item label="手机号码:" prop="phone">
        <el-input v-model="form.phone" placeholder="请输入" maxlength="11" />
      </el-form-item>
      <el-form-item label="身份证号码:" prop="IdCard">
        <el-input v-model="form.IdCard" placeholder="请输入" maxlength="18" />
      </el-form-item>
      <el-form-item label="整数:" prop="num">
        <el-input v-model="form.num" placeholder="请输入" maxlength="10" />
      </el-form-item>
      <el-form-item label="汉字:" prop="hz">
        <el-input v-model="form.hz" placeholder="请输入" maxlength="10" />
      </el-form-item>
      <div class="forTitle">for循环列表的表单校验</div>
      <div class="list" v-for="(item,index) in form.list" :key="item.index">
        <el-row :gutter="20" type="flex">
          <el-col :span="11">
            <el-form-item label="标题:" :prop="`list.${index}.title`" :rules='rules.title'>
        <el-input v-model="item.title" placeholder="请输入" maxlength="10" />
      </el-form-item>
          </el-col>
          <el-col :span="11">
            <el-form-item label="类型:" :prop="`list.${index}.type`" :rules='rules.type'>
        <el-input v-model="item.type" placeholder="请输入" maxlength="10" />
      </el-form-item>
          </el-col>
        </el-row>
      </div>

    </el-form>
    <div>
      <el-button type="primary" @click="submitForm">保 存</el-button>
    </div>
  </div>
</template>
    
<script>
export default {
  name: "FormPage",
  data() {
    //身份证号格式校验
    var isCardId = (rule, value, callback) => {
      if (value) {
        const reg =
          /^\d{6}(18|19|20)?\d{2}(0[1-9]|1[0-2])(([0-2][1-9])|10|20|30|31)\d{3}(\d|X|x)$/;
        const card = reg.test(value);
        if (!card) {
          callback(new Error("身份证号格式有误!"));
        } else {
          callback();
        }
      } else {
        callback();
      }
      callback();
    };
    //手机号格式校验
    var validatorPhone = function (rule, value, callback) {
      if (value) {
        if (!/^1\d{10}$/.test(value)) {
          callback(new Error('手机号格式错误'))
        } else {
          callback()
        }
      }
      callback();
    };
    return {
      form: {
        name: '',
        phone: "",
        IdCard: "",
        num: '',
        hz: '',
        list: [
          {
            title: '',
            type: '',
          },
          {
            title: '',
            type: '',
          },
        ],
      },
      // 表单校验
      rules: {
        name: [{
          required: true,
          message: "请输入姓名",
          trigger: ["blur", "change"]
        },],
        IdCard: [
          {
            validator: isCardId,
            trigger: ["blur", "change"]
          }
        ],
        phone: [
          {
            required: true,
            message: "请输入手机号",
            trigger: ["blur", "change"]
          },
          {
            validator: validatorPhone,
            trigger: ["blur", "change"]
          }
        ],
        num: [
          {
            required: true,
            message: "请输入数字",
            trigger: ["blur", "change"]
          },
          { pattern: /^[0-9]*$/, message: '请输入数字', trigger: 'blur' },
        ],
        hz: [
          { min: 3, max: 5, message: '长度在 3 到 5 个字符', trigger: 'blur' },
          { pattern: /^[\u4e00-\u9fa5]{0,}$/, message: "请输入汉字", trigger: "blur" }
        ],

        title: [{
          required: true,
          message: "请输入标题",
          trigger: ["blur", "change"]
        },],
        type: [{
          required: true,
          message: "请输入类型",
          trigger: ["blur", "change"]
        },],

      },
    };
  },
  methods: {
    /** 提交按钮 */
    submitForm() {
      console.log(this.form, 'this.form')
      this.$refs["form"].validate((valid) => {
        if (valid) {
          console.log('提交!')
        }
      });
    },
  },
};
</script>
  
<style scoped>
.forTitle{
margin-bottom: 20px;
}
</style>
    

在这里插入图片描述

  • 8
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
element form表单校验是一种常用的前端表单校验方式,可以有效地对表单输入的内容进行验证,提高用户输入的准确性和数据的有效性。下面是element form表单校验的行内写法的解释。 Element form表单校验的行内写法主要是通过在input标签上添加相关属性来定义校验规则,实现对表单输入的校验。其中常用的属性包括:required、pattern、min、max、minlength、maxlength、type等。 首先,我们需要在input标签上添加required属性,用于设置必填项的校验规则。这样可以确保用户必须填写该字段,否则会弹出错误提示。 其次,我们可以使用pattern属性,通过正则表达式来定义输入内容的格式。例如,pattern="[a-zA-Z0-9]+"表示输入内容只能包含字母和数字。 另外,我们还可以使用min和max属性,用于限制输入的最小值和最大值。例如,min="1"和max="100"表示输入内容必须在1到100之间。 此外,如果我们需要限制输入内容的长度,可以使用minlength和maxlength属性。例如,minlength="6"和maxlength="12"表示输入内容的长度必须在6到12个字符之间。 最后,type属性可以用来指定输入内容的类型,例如email、tel、url等。这样可以对不同类型的输入进行相应的校验。 总的来说,element form表单校验的行内写法通过在input标签上添加相关属性,实现对表单输入的校验。这种写法简单方便,适用于表单校验需求简单的场景。但对于复杂的校验规则,建议使用element form表单校验的自定义写法,通过js代码来实现更灵活的校验逻辑。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值