美文网首页
el-form 表单遍历,校验失败原因

el-form 表单遍历,校验失败原因

作者: status_200 | 来源:发表于2023-03-07 11:34 被阅读0次

官网有动态增减表单项示例
https://element.eleme.io/#/zh-CN/component/form
其中最重要的配置是表单项的prop属性拼接
拼接失败则无法正常校验
:prop="'domains.' + index + '.value'"
拼接的是通过model绑定的对象的domains,为动态数组;index为遍历的下标;value为希望绑定的属性名称

<el-form :model="dynamicValidateForm" ref="dynamicValidateForm" label-width="100px" class="demo-dynamic">
  <el-form-item
    prop="email"
    label="邮箱"
    :rules="[
      { required: true, message: '请输入邮箱地址', trigger: 'blur' },
      { type: 'email', message: '请输入正确的邮箱地址', trigger: ['blur', 'change'] }
    ]"
  >
    <el-input v-model="dynamicValidateForm.email"></el-input>
  </el-form-item>
  <el-form-item
    v-for="(domain, index) in dynamicValidateForm.domains"
    :label="'域名' + index"
    :key="domain.key"
    :prop="'domains.' + index + '.value'"
    :rules="{
      required: true, message: '域名不能为空', trigger: 'blur'
    }"
  >
    <el-input v-model="domain.value"></el-input><el-button @click.prevent="removeDomain(domain)">删除</el-button>
  </el-form-item>
  <el-form-item>
    <el-button type="primary" @click="submitForm('dynamicValidateForm')">提交</el-button>
    <el-button @click="addDomain">新增域名</el-button>
    <el-button @click="resetForm('dynamicValidateForm')">重置</el-button>
  </el-form-item>
</el-form>
<script>
  export default {
    data() {
      return {
        dynamicValidateForm: {
          domains: [{
            value: ''
          }],
          email: ''
        }
      };
    },
    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();
      },
      removeDomain(item) {
        var index = this.dynamicValidateForm.domains.indexOf(item)
        if (index !== -1) {
          this.dynamicValidateForm.domains.splice(index, 1)
        }
      },
      addDomain() {
        this.dynamicValidateForm.domains.push({
          value: '',
          key: Date.now()
        });
      }
    }
  }
</script>

如果拼接字段写成
:prop="'domains.' + index + '.value1'"
或者
:prop="'domains1.' + index + '.value'"
则无法正常校验


image.png

相关文章

  • voltType is not a string

    el-form表单校验时报错 项目需求要对输入的表单内容进行类型和长度校验,其他格式都没问题,唯独是数字类型和长度...

  • elementUI el-form validate方法不执行

    表单组件 el-form validate 方法不执行,检查自定义校验规则方法,是否执行了 callback 方法。

  • vue3 二次封装el-form表单

    二次封装el-form,理由无非就是多个地方用同一个表单,懒得重复写校验。 表单组件 组件的使用

  • el-form校验失败

    表单校验不报错,但是校验方法一直进不去,原因是因为自定义校验规则的时候没有else callback()

  • Vue.js-ElementUI表单

    1 表单el-form 每个表单el-form由多个表单域el-form-item组成。默认情况,表单域是垂直分布...

  • el-form表单循环校验

    element-ui中el-form表单项循环渲染,并添加相关校验 关于这类功能需求,项目中还是挺常见的,所以今天...

  • antd - form表单校验踩坑记录

    form表单校验时,发现提示信息一直不显示 原因:是因为form表单中有用到了自定义校验,但是callback没有...

  • CSS文本超出希望右对齐

    在做form表单校验时,经常会出现但是校验失败的提示文本超出校验项宽度的现象: 当超出校验项宽度时,文本换行展示了...

  • Element-UI表单验证

    校验规则 表单通过rules属性绑定校验规则对象,表单项通过prop属性绑定具体校验规则 注意校验的字段必须和表单...

  • elementUI form表单校验报错

    elementUI form表单动态增加表单项使用v-for进行表单校验时报错,报错信息如下: 主要原因是el-f...

网友评论

      本文标题:el-form 表单遍历,校验失败原因

      本文链接:https://www.haomeiwen.com/subject/krvmldtx.html