element ui table嵌套多个select,包含动态列

先来看一下效果图,前面的部分是普通列,“工艺”、“模面”、“结构”三列是查询得到得动态列

 vue部分代码

关键点在于el-select中得v-model部分 需要使用scope.row[scope.column.property]来绑定某一个单元格,否则按网上大部分文章中使用scope.row.xxx会让整行的下拉都随某一个下拉值的改变而改变

<el-table
      :data="planTemplateList"
      border
      ref="table"
      id="table"
      :height="tableHeight"
      size="small"
      highlight-current-row
    >
      <!-- moldId -->
      <el-table-column
        type="index"
        label="序号"
        align="center"
        width="50"
      >
      </el-table-column>
      <el-table-column
        prop="makeCode"
        label="制件图号"
        show-overflow-tooltip
        align="center"
        sortable
        width="150"
      >
      </el-table-column>
      <el-table-column
        prop="makeName"
        label="制件名称"
        show-overflow-tooltip
        align="center"
        sortable
        width="150"
      >
      </el-table-column>
      <el-table-column
        prop="moldCode"
        label="模具制号"
        show-overflow-tooltip
        align="center"
        sortable
        width="110"
      >
      </el-table-column>
      <el-table-column
        prop="standSet"
        label="标准套(C)"
        show-overflow-tooltip
        align="center"
        sortable
        width="110"
      >
      </el-table-column>
      <el-table-column v-for="(col, index) in groupColums"
        :prop="col.prop"
        :label="col.label"
        :key="col.prop + index"
        show-overflow-tooltip
        align="center"
        sortable
        width="150"
      >
        <template slot-scope="scope">
          <el-select v-model="scope.row[scope.column.property]" @change="(value)=> 
               {changeCell(value, scope.row, col.prop)}" clearable filterable>
            <el-option
              v-for="item in designAssignDeptList"
              :key="item.key"
              :label="item.value"
              :value="item.key">
            </el-option>
          </el-select>
        </template>
      </el-table-column>
      <el-table-column v-for="(col, index) in groupColums"
        :prop="col.prop"
        :label="col.label"
        :key="index"
        align="center"
      >
        <el-table-column v-for="(itemCol, itemIndex) in planTemplateColums"
          v-if="itemCol.parentKey === col.prop"
          :prop="itemCol.prop"
          :label="itemCol.label"
          :key="itemIndex"
          show-overflow-tooltip
          align="center"
          sortable
          width="150"
        >
          <template slot-scope="scope">
            <el-select v-model="scope.row[scope.column.property]" clearable filterable>
              <el-option
                v-for="item in designAssignDeptList"
                :key="item.key"
                :label="item.value"
                :value="item.key">
              </el-option>
            </el-select>
          </template>
        </el-table-column>
      </el-table-column>
      <el-table-column
        label="操作"
        align="center"
        fixed="right"
        width="80"
      >
        <template slot-scope="scope">
          <el-button type="danger" @click="clearRow(scope.row)" plain icon="el-icon-        
             delete" circle size="mini" title="清空"></el-button>
        </template>
      </el-table-column>
    </el-table>

js部分代码

export default {
  name: 'distributeDept',
  data () {
    return {
      planTemplateList: [], // 计划模板列表
      groupColums: [], // 工序组表头
      designAssignDeptList: [] // 设计任务分配部门下拉
    }
  },
  created () {
    this.getGroupTitle()
    this.getDesignAssignDeptList()
    this.getList()
  },
  mounted () {

  },
  computed: {

  },
  methods: {

    async getGroupTitle () {
      // 获取工序分组动态列头
      const res = await this.$http.request({ url: this.$api.baseConfig.getDictDataList,
        params: {
          dictType: 'pln_progress_group'
        },
        method: 'get' })
      const data = res.data
      if (data.code === 0) {
        this.groupColums.splice(0, this.groupColums.length)
        for (var i = 0; i < data.jsonObject.length; i++) {
          this.groupColums.push({
            label: data.jsonObject[i].dictLabel,
            prop: String(data.jsonObject[i].dictValue)
          })
        }
      }
    },

    async getDesignAssignDeptList () {
      // 获取设计任务分配部门下拉

      const res = await this.$http.request({
        url: this.$api.pln.getDesignAssignDeptList,
        params: {

        },
        method: 'get'
      })
      const data = res.data
      if (data.code === 0) {
        this.designAssignDeptList = data.jsonObject
      }
    },

    async getList () {
      // 获取工序分配列表
      this.search_loading = true

      const res = await this.$http.request({
        url: this.$api.pln.getDistributeDeptList,
        params: {
          projectIds: this.idString
        },
        method: 'get'
      })
      const data = res.data
      if (data.code === 0) {
        this.search_loading = false
        const results = []
        let moldId = null
        let obj = null
        for (let i = 0; i < data.jsonObject.length; i++) {
          if (moldId !== data.jsonObject[i].moldId) {
            // 新增一行
            obj = {
              makeCode: data.jsonObject[i].makeCode,
              makeName: data.jsonObject[i].makeName,
              moldId: data.jsonObject[i].moldId,
              moldCode: data.jsonObject[i].moldCode,
              standSet: data.jsonObject[i].standSet
            }
            this.$set(obj, data.jsonObject[i].prop, data.jsonObject[i].value)
            moldId = data.jsonObject[i].moldId
            results.push(obj)
          } else {
            // 合并列
            this.$set(obj, data.jsonObject[i].prop, data.jsonObject[i].value)
          }
        }
        this.planTemplateList = results
      }
    },

    changeCell (value, row, prop) {
      this.planTemplateColums.forEach(item => {
        if (item.parentKey === prop) {
          // 找到parentKey是prop的列 获取列的数组 将row中的这些列改值
          this.$set(row, item.prop, value)
        }
      })
    },

    clearRow (row) {
      // 清空当前行
      this.groupColums.forEach(item => {
        this.$set(row, item.prop, null)
      })
      this.planTemplateColums.forEach(item => {
        this.$set(row, item.prop, null)
      })
    }

  }
}

 

  • 10
    点赞
  • 32
    收藏
    觉得还不错? 一键收藏
  • 9
    评论
### 回答1: 在Element UI中,可以使用Table组件来嵌套表格。具体实现方法是在Table的columns中定义一个子表格的column,然后在父表格的数据中添加一个子表格的数据数组。当用户点击父表格的某一行时,子表格会展开并显示对应的子表格数据。同时,可以通过设置expand-row-keys属性来控制哪些行需要展开子表格。 ### 回答2: Element UI中的Table组件是一个非常常用的表格组件,提供了非常灵活的表格展示和操作。而嵌套表格则是在Table中的一种比较特殊的展示方式,可用于在当前表格内,在某些行的详细信息下展开一张子表格。 使用Element UITable嵌套表格,有以下几个基本步骤: 1.首先需要在父表格(主表格)的columns中添加一个slot来展示子表格的内容: ```javascript columns: [ { label: '姓名', prop: 'name' }, { label: '年龄', prop: 'age' }, { label: '操作', slot: 'actions' } ] ``` 在父表格的上述例子中,我们为“操作”添加了一个`slot: 'actions'`,这里的actions是指在子组件中要用到的那个slot名字,代表着在子表格中要插入的内容。 2.添加子表格组件,并在子组件中通过slot-scope获取父子数据并展示子表格数据: ```vue <template> <el-table :data="data" style="width: 100%"> <el-table-column prop="date" label="日期" width="180"> </el-table-column> <el-table-column prop="name" label="姓名"> </el-table-column> <el-table-column prop="address" label="地址"> </el-table-column> </el-table> </template> <script> export default { props: { prop: String, row: Object }, data() { return { data: [ { date: '2016-05-02', name: '王小虎', address: '上海市普陀区金沙江路 1518 弄' }, { date: '2016-05-04', name: '王小虎', address: '上海市普陀区金沙江路 1518 弄' }, { date: '2016-05-01', name: '王小虎', address: '上海市普陀区金沙江路 1518 弄' }, { date: '2016-05-03', name: '王小虎', address: '上海市普陀区金沙江路 1518 弄' }, ] } } } </script> ``` 在子组件中我们通过父组件传递过来的数据`prop: String, row: Object`作为查询参数,来获取展示子表格的数据,并通过`slot-scope`在父组件中添加插槽来展示子组件内容。 3.在父组件中的操作中通过scoped slot插入子组件: ```vue <el-table-column label="操作" width="120"> <template slot-scope="scope"> <el-button type="primary" @click.prevent.stop="handleOpen(scope.row)"> 添加子表格 </el-button> <el-table :data="[scope.row]" v-show="scope.row.children && scope.row.children.length > 0"> <el-table-column type="expand" label=""> <template slot-scope="props"> <children-table :prop="scope.column.prop" :row="props.row"> </children-table> </template> </el-table-column> </el-table> </template> </el-table-column> ``` 父组件中的操作包含了一个添加子表格的按钮和一个子表格展开的图标,当用户点击添加子表格的时候,会调用handleOpen方法,在此方法中可以进行一些操作,比如网络请求,获取子表格数据等等。当用户点击子表格展开的图标时,会展开子表格,进而呈现子组件中的内容。 总的来说,Element UI中的Table嵌套表格是一种非常常见的表格展示方式,可以帮助用户更加详细地了解表格数据内容,在实际开发中应用也比较广泛,值得学习和掌握。 ### 回答3: 随着前端开发的不断发展,表格是展示数据的重要组件之一。Element UI是基于Vue.js的UI组件库,提供了功能强大、易于使用的表格组件,可以快速地实现各种表格需求。在很多情况下,在一个表格中嵌套另一个表格是一种特殊的需求,这时候我们可以借助Element UITable插槽来实现。 在Element UI中,给表格设置scoped-slot,即插槽,可以在每一行的数据中增加自己想要的内容,这样就可以通过插槽嵌套表格。 嵌套表格的特别之处在于数据源的构造。外层表格中每一行的数据需要嵌套表格所需的子数据。在表格中设置scoped-slot之后,可以通过js的逻辑处理来为每一行数据增加子数据属性,使得在一行数据中展示一个表格,并向里面传入嵌套表格所需的子数据。 除此之外,Element UI也提供了一些便捷的函数和属性以处理复杂的嵌套表格需求。嵌套表格的cell-style、row-style、fixed、selection、index等属性都可以灵活配合使用,使得表格嵌套表格以及数据的展示更加灵活多样。同时还有一些针对单元格的通用插槽,如cell、header-cell、expand等,可以快速地实现单元格的自定义展示。 总的来说,在Element UI嵌套表格是一种非常强大的功能,用于复杂和大型数据集的展示,提供了丰富的组件和插槽,可以灵活地满足各种嵌套表格需求。通过使用这些方法,不仅可以快速地构建数据展示,同时也提升了用户的体验感。
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值