vue form表单下嵌套表格 并校验每一行

该代码示例展示了如何在Vue.js中创建一个可编辑的数据表格,包括表头渲染、表单验证、数据操作(添加、删除)以及自定义列渲染功能。用户在表格内输入内容后,可以执行保存操作,且表单字段需通过验证。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<template>
  <div class="">
    <TableTop isFlex title="xxx" :border="false">
      <template slot="tableList">
        <div class="">
          <el-form :model="form" :rules="rules" ref="form">
            <el-table :data="form.tableData" style="width: 100%">
              <el-table-column type="index" label="序号" width="50"> </el-table-column>
              <el-table-column label="竞价项目名称" min-width="180" show-overflow-tooltip :render-header="addRedStar">
                <template slot-scope="scope">
                  <el-form-item
                    :prop="'tableData.' + scope.$index + '.ipt'"
                    :rules="{ required: true, message: '必填', trigger: 'blur' }"
                  >
                    <el-input v-model="scope.row.ipt"></el-input>
                  </el-form-item>
                </template>
              </el-table-column>  
              <el-table-column prop="name" label="操作" width="240" fixed="right">
                <template slot-scope="scope">
                  <el-button type="text" @click="saveBtn">保存</el-button>
                  <el-button type="text" @click="delBtn(scope.row, scope.$index)">删除</el-button>
                </template>
              </el-table-column>
            </el-table>
          </el-form>
        </div>
      </template>
    </TableTop>
  </div>
</template>

<script>
import TableTop from '@/components/TableTop/tableTop.vue'
export default {
  data() {
    return {
      form: {
        tableData: [
          { name: '2121', ipt: '内容' },
          { name: '2121', ipt: '内容' },
          { name: '2121', ipt: '内容' },
          { name: '2121', ipt: '内容' }
        ]
      },
      rules: {
        name: [{ required: true, message: '名字不能为空', trigger: 'blur' }],
        age: [{ required: true, message: '年龄不能为空', trigger: 'blur' }]
      },
    }
  },
  methods: {
    add() {
      this.form.tableData.push({ name: '2121', ipt: '内容' })
    },
    delBtn(row, index) {
      this.form.tableData.splice(index, 1)
    },
    saveBtn() {
      this.$refs.form.validate((valid) => {
        if (valid) {
          console.log('通过')
          console.log(this.form.tableData)
        }
      })
    },
    addRedStar(h, { column }) {
      return [h('span', { style: 'color:#f00' }, '*'), h('span', ' ' + column.label)]
    },
  },
  components: {
    TableTop,
    MaterialDetailsInfo
  }
}
</script>

<style lang="less" scoped>
</style>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值