1.实现效果




element puls 提交多个循环表单_数组


2.代码逻辑

此段代码是建立在Elemet ui 中的el-date-picker时间控件上实现的

<template>
  <div class="back">
    <el-form ref="form" :rules="rules" :model="rules">
      <el-form-item label="请选择时间范围" :required="true" :rules="rules" class="form-y" prop="subscribe_time">
        <div v-for="(item, index) in subscribe_time" :key="index" style="display: flex; align-items: center ;margin-top: 10px;">
          <el-form-item>
            <el-date-picker v-model="item.time" value-format="yyyy-MM-dd" type="daterange" range-separator="至" start-placeholder="开始日期" end-placeholder="结束日期"> </el-date-picker>
          </el-form-item>
          <i class="el-icon-remove-outline" style="color: red; font-size: 20px; margin: 0 5px" @click="deletes(item, index)"></i>
        </div>
        <span style="color: #3d7fff; cursor: pointer" @click="add" @change="$forceUpdate()">+ 添加预约时间</span>
      </el-form-item>
    </el-form>
  </div>
</template>
<template>
  <div class="back">
    <el-form ref="form" :rules="rules" :model="rules">
      <el-form-item label="请选择时间范围" :required="true" :rules="rules" class="form-y" prop="subscribe_time">
        <div v-for="(item, index) in subscribe_time" :key="index" style="display: flex; align-items: center ;margin-top: 10px;">
          <el-form-item>
            <el-date-picker v-model="item.time" value-format="yyyy-MM-dd" type="daterange" range-separator="至" start-placeholder="开始日期" end-placeholder="结束日期"> </el-date-picker>
          </el-form-item>
          <i class="el-icon-remove-outline" style="color: red; font-size: 20px; margin: 0 5px" @click="deletes(item, index)"></i>
        </div>
        <span style="color: #3d7fff; cursor: pointer" @click="add" @change="$forceUpdate()">+ 添加预约时间</span>
      </el-form-item>
    </el-form>
  </div>
</template>

由于el-date-picker需要el-form进行包裹所以需要进行ref的绑定

在form中设置一个初始的subscribe_time空数组

这边根据需求来给他进行rules必填判断

还需要给时间选择器一个默认值

data () {
    return {
        // 初始的form
        form: {
            subscribe_time: []
        },
        // 必填判断
        rules: {
            subscribe_time: [
                { required: true, message: '请选择报名时间', trigger: 'change' }
            ]
        },
        // 时间选择默认值
        subscribe_time: [{ time: '' }]
    }
},
data () {
    return {
        // 初始的form
        form: {
            subscribe_time: []
        },
        // 必填判断
        rules: {
            subscribe_time: [
                { required: true, message: '请选择报名时间', trigger: 'change' }
            ]
        },
        // 时间选择默认值
        subscribe_time: [{ time: '' }]
    }
},

初始值设置完成就开始进行逻辑部分

请在methods中添加以下事件

在第一段代码块中的Span中设置的一个点击事件来进行新添加一个el-date-picker组件

在Span行内Css中的cursor属性是改变指针指向状态的

pointer便是把指针换为小手

// 添加预约时间
add () {
    this.subscribe_time.push({
        time: ''
    })
},
// 添加预约时间
add () {
    this.subscribe_time.push({
        time: ''
    })
},

以下代码块是删除的逻辑

判断是否是最后一个el-date-picker组件

如果是就给他提示至少保留一个时间段

这边传入的两个形参分别为

_item删除的对象

index被删除的下标是多少

然后用数组方法splice来进行删除操作

deletes (_item, index) {
    if (this.subscribe_time.length <= 1) {
        this.$message({
            message: '至少保留一个时间段',
            type: 'warning'
        })
        /// 如果只有一个框则不可以删除
        return false
    }
    this.subscribe_time.splice(index, 1) // 删除数组中对应的数据也就是将这个位置的框删除
    this.form.subscribe_time.splice(index, 1) // 删除数组中对应的数据也就是将这个位置的框删除
}
deletes (_item, index) {
    if (this.subscribe_time.length <= 1) {
        this.$message({
            message: '至少保留一个时间段',
            type: 'warning'
        })
        /// 如果只有一个框则不可以删除
        return false
    }
    this.subscribe_time.splice(index, 1) // 删除数组中对应的数据也就是将这个位置的框删除
    this.form.subscribe_time.splice(index, 1) // 删除数组中对应的数据也就是将这个位置的框删除
}

以下代码块需要写在watch监听方法中

在监听到subscribe_time数据改变时就会触发里面的代码逻辑

// 监听选择时间
subscribe_time: {
    handler (newVal) {
        // 创建一个新的数组来装循环出来的数组
        let contentItem = []
        // 把默认的from数组变为空来进行下面的操作
        this.form.subscribe_time = []
        // 开始循环时间数组
        newVal.forEach((v) => {
            if (v.time.length > 0) {
                // 把time中的值循环出来
                contentItem = v.time
                // push进新的数组中
                this.form.subscribe_time.push(contentItem)
            }
        })
    },
    immediate: true,
    deep: true
}
// 监听选择时间
subscribe_time: {
    handler (newVal) {
        // 创建一个新的数组来装循环出来的数组
        let contentItem = []
        // 把默认的from数组变为空来进行下面的操作
        this.form.subscribe_time = []
        // 开始循环时间数组
        newVal.forEach((v) => {
            if (v.time.length > 0) {
                // 把time中的值循环出来
                contentItem = v.time
                // push进新的数组中
                this.form.subscribe_time.push(contentItem)
            }
        })
    },
    immediate: true,
    deep: true
}

以上代码直接复制即可使用

如果需求有出入 自行修改一下即可

完整代码块在以下

<template>
  <div class="back">
    <el-form ref="form" :rules="rules" :model="rules">
      <el-form-item label="请选择时间范围" :required="true" :rules="rules" class="form-y" prop="subscribe_time">
        <div v-for="(item, index) in subscribe_time" :key="index" style="display: flex; align-items: center ;margin-top: 10px;">
          <el-form-item>
            <el-date-picker v-model="item.time" value-format="yyyy-MM-dd" type="daterange" range-separator="至" start-placeholder="开始日期" end-placeholder="结束日期"> </el-date-picker>
          </el-form-item>
          <i class="el-icon-remove-outline" style="color: red; font-size: 20px; margin: 0 5px" @click="deletes(item, index)"></i>
        </div>
        <span style="color: #3d7fff; cursor: pointer" @click="add" @change="$forceUpdate()">+ 添加预约时间</span>
      </el-form-item>
    </el-form>
  </div>
</template>

<script>
export default {
  data () {
    return {
      form: {
        subscribe_time: []
      },
      rules: {
        subscribe_time: [
          { required: true, message: '请选择报名时间', trigger: 'change' }
        ]
      },
      // 时间选择默认值
      subscribe_time: [{ time: '' }]
    }
  },
  methods: {
    // 添加预约时间
    add () {
      this.subscribe_time.push({
        time: ''
      })
    },
    // 删除预约时间
    deletes (_item, index) {
      if (this.subscribe_time.length <= 1) {
        this.$message({
          message: '至少保留一个预约时间段',
          type: 'warning'
        })
        /// 如果只有一个框则不可以删除
        return false
      }
      this.subscribe_time.splice(index, 1) // 删除数组中对应的数据也就是将这个位置的框删除
      this.form.subscribe_time.splice(index, 1) // 删除数组中对应的数据也就是将这个位置的框删除
    }
  },
  watch: {
    subscribe_time: {
            handler (newVal) {
                // 创建一个新的数组来装循环出来的数组
                let contentItem = []
                // 把默认的from数组变为空来进行下面的操作
                this.form.subscribe_time = []
                // 开始循环时间数组
                newVal.forEach((v) => {
                    if (v.time.length > 0) {
                        // 把time中的值循环出来
                        contentItem = v.time
                        // push进新的数组中
                        this.form.subscribe_time.push(contentItem)
                    }
                })
            },
            immediate: true,
            deep: true
        }
    }
}
</script>
<style lang="less" scoped>
/deep/ .el-form-item__label{
  float: none !important;
}
</style>
<template>
  <div class="back">
    <el-form ref="form" :rules="rules" :model="rules">
      <el-form-item label="请选择时间范围" :required="true" :rules="rules" class="form-y" prop="subscribe_time">
        <div v-for="(item, index) in subscribe_time" :key="index" style="display: flex; align-items: center ;margin-top: 10px;">
          <el-form-item>
            <el-date-picker v-model="item.time" value-format="yyyy-MM-dd" type="daterange" range-separator="至" start-placeholder="开始日期" end-placeholder="结束日期"> </el-date-picker>
          </el-form-item>
          <i class="el-icon-remove-outline" style="color: red; font-size: 20px; margin: 0 5px" @click="deletes(item, index)"></i>
        </div>
        <span style="color: #3d7fff; cursor: pointer" @click="add" @change="$forceUpdate()">+ 添加预约时间</span>
      </el-form-item>
    </el-form>
  </div>
</template>

<script>
export default {
  data () {
    return {
      form: {
        subscribe_time: []
      },
      rules: {
        subscribe_time: [
          { required: true, message: '请选择报名时间', trigger: 'change' }
        ]
      },
      // 时间选择默认值
      subscribe_time: [{ time: '' }]
    }
  },
  methods: {
    // 添加预约时间
    add () {
      this.subscribe_time.push({
        time: ''
      })
    },
    // 删除预约时间
    deletes (_item, index) {
      if (this.subscribe_time.length <= 1) {
        this.$message({
          message: '至少保留一个预约时间段',
          type: 'warning'
        })
        /// 如果只有一个框则不可以删除
        return false
      }
      this.subscribe_time.splice(index, 1) // 删除数组中对应的数据也就是将这个位置的框删除
      this.form.subscribe_time.splice(index, 1) // 删除数组中对应的数据也就是将这个位置的框删除
    }
  },
  watch: {
    subscribe_time: {
            handler (newVal) {
                // 创建一个新的数组来装循环出来的数组
                let contentItem = []
                // 把默认的from数组变为空来进行下面的操作
                this.form.subscribe_time = []
                // 开始循环时间数组
                newVal.forEach((v) => {
                    if (v.time.length > 0) {
                        // 把time中的值循环出来
                        contentItem = v.time
                        // push进新的数组中
                        this.form.subscribe_time.push(contentItem)
                    }
                })
            },
            immediate: true,
            deep: true
        }
    }
}
</script>
<style lang="less" scoped>
/deep/ .el-form-item__label{
  float: none !important;
}
</style>