Vue el-from的el-form-item v-for循环表单如何校验rules(二)

在上一篇文章中,通过校验规则写成内联循环去校验from表单项,在之前的代码基础上,进行校验规则的二次封装,使代码更加简洁,灵活高效、

参考上一篇:Vue el-from的el-form-item v-for循环表单如何校验rules(一)-CSDN博客

1、需求效果

2、完整代码

复制代码
<template>
 <ul class="violation-content">
   <li v-for="(item,index) in formData.tableData" :key="item.key">
      <div class="content-item">
        <el-form-item :prop="`tableData[${index}].name`" label-width="1" style="margin-bottom: 0;">
               <el-input type="text" clearable placeholder="请输入" v-model.trim="item.name"></el-input>
         </el-form-item>
        </div>
        <div class="content-item">
          <span @click="delete(index)">删除</span>
          <el-button type="primary" v-if="index === (formData.tableData.length-1)" @click="add">添加</el-button>
     </div>
   </li>
 </ul>
</template>
export default {
  data() {
    return {
      rules: {

      },
      formData:{
         tableData: [],
      }
    };
  },
 

  created() {
      this.$set(this.formData, 'tableData', [{name: '', key: Date.now()}])
      this.addRules()
  }, 

  methods: {
    
    add() {
      this.formData.tableData.push({
        name: '',
        key: Date.now()
      })
      this.addRules()
    },
    delete(index) {
      this.formData.tableData.splice(index, 1)
    },
    addRules() {
      let leng = this.formData.tableData.length
      for(let i = 0; i < leng; i++) {
        this.rules[`tableData[${i}].name`] = [
          { required: true, message: '请输入', trigger: 'blur'}
        ]
      }
    },
  },
};
</script>

写在最后!!!

v-for循环对象的时候,是可以获得三个参数的,其中第一个参数是对象每一项的value值,第二个参数是每一项的key值,第三个参数是索引值,这里使用:prop="key+'.对应的key'"即可(不要漏了单引号里面的点)。循环对象的话是可以获得两个参数,其中第一个是数组的每一项,第二个参数是数组的下标,其实和对象是差不多的,v-for="(item,index) in array" , :prop="`array[${index}].name`"

相关推荐
用户8417948145617 分钟前
vxe-gantt 甘特图实现产品进度列表,自定义任务条样式和提示信息
vue.js
招来红月2 小时前
记录JS 实用API
javascript
别叫我->学废了->lol在线等2 小时前
演示 hasattr 和 ** 解包操作符
开发语言·前端·python
霍夫曼2 小时前
UTC时间与本地时间转换问题
java·linux·服务器·前端·javascript
VX:Fegn08952 小时前
计算机毕业设计|基于Java人力资源管理系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot·后端·课程设计
DARLING Zero two♡2 小时前
浏览器里跑 AI 语音转写?Whisper Web + cpolar让本地服务跑遍全网
前端·人工智能·whisper
꒰ঌ小武໒꒱2 小时前
文件上传全维度知识体系:从基础原理到高级优化
javascript·node.js
Lovely Ruby2 小时前
前端er Go-Frame 的学习笔记:实现 to-do 功能(三),用 docker 封装成镜像,并且同时启动前后端数据库服务
前端·学习·golang
老华带你飞2 小时前
健身房|基于springboot + vue健身房管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端
JIngJaneIL3 小时前
基于Java酒店预约系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot