el-form中嵌套一个el-form 进行表单校验

 数据格式为form对象中嵌套一层可循环数组,数组内嵌套table表格,也可循环

form: {
  id: row.id,
  process: [{
   code: '',
    log: [{
      id: ''
    }]
  }]
}
<el-form :model="form" ref="form" v-for="(item, index) in form.process" :key="index" class="bord">
  <el-form-item
    :prop="'process.' + index + '.code'"
    :rules="[{ required: true, message: '请选择数据', trigger: 'change' }]"
  >
  <el-select v-model="item.code" placeholder="请选择数据" @change="getChange(item,item.code)">
   <el-option
   v-for="i in data"
    :key="i.value"
    :label="i.label"
    :value="i.value"
    />
   </el-select>
  </el-form-item>
  <el-form :model="form.process[index]" ref="process.lage">
    <el-table
      ref="lage"
      class="sort-table"
      v-model="item.lage"
      :data="item.lage"
      max-height="240"
      :header-cell-style="{textAlign: 'center'}"
      :cell-style="{ textAlign: 'center' }"
     >
     <el-table-column
       type="index"
       label="序号"
       width="60"
      />
     <el-table-column
       prop="id"
       label="节点id"
       width="80"
     >
      <template v-slot="scope">
        <el-form-item
         :prop="'lage.' + scope.$index + '.id'"
         :rules="[{ required: true, message: '请输入id', trigger: 'blur' }]"
        >
          <el-input v-model="scope.row.id" placeholder="请输入id" />
        </el-form-item>
       </template>
      </el-table-column>
     </el-table>
  </el-form>
</el-form>

 点击按钮提交表单时校验

save() {
  Promise.all([this.$refs['form'][0].validate(), this.$refs['process.lage'][0].validate()]).then(() => {
    //接口等一系列正常操作
    })
  })
},

  • 4
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用`el-form`表单组件嵌套一个`el-form`表单组件。这种嵌套可以用于更复杂的表单布局和组织。 以下是一个示例代码,演示了如何嵌套`el-form`表单: ```vue <template> <el-form ref="outerForm" :model="outerForm" label-width="100px"> <el-form-item label="外层表单项"> <el-input v-model="outerForm.field1"></el-input> </el-form-item> <el-form ref="innerForm" :model="innerForm" label-width="100px"> <el-form-item label="内层表单项"> <el-input v-model="innerForm.field2"></el-input> </el-form-item> </el-form> <el-form-item> <el-button type="primary" @click="submitForm">提交</el-button> </el-form-item> </el-form> </template> <script> export default { data() { return { outerForm: { field1: '' }, innerForm: { field2: '' } }; }, methods: { submitForm() { this.$refs.outerForm.validate((validOuterForm) => { if (validOuterForm) { // 外层表单校验通过 this.$refs.innerForm.validate((validInnerForm) => { if (validInnerForm) { // 内层表单校验通过,提交数据 console.log(this.outerForm); console.log(this.innerForm); } else { // 内层表单校验不通过 return false; } }); } else { // 外层表单校验不通过 return false; } }); } } }; </script> ``` 在上面的示例,外层表单和内层表单都使用了`el-form`组件,并且分别定义了自己的数据模型(`outerForm`和`innerForm`)。你可以根据实际需要添加更多的表单项。 请注意,在提交表单时,需要先校验外层表单的有效性,然后再校验内层表单的有效性。只有当两个表单校验通过时,才会提交数据。 希望这个例子对你有所帮助!如果你还有其他问题,请随时提问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值