**elementui 树形表格 全部展开及收起功能**

elementui 树形表格 全部展开及收起功能
在这里插入图片描述
使用: this.$refs.theTable.toggleRowExpansion(row, true)
需求简说: 树形表格上方提供两个按钮: “展开全部” “收起全部”
逻辑简说: 递归遍历赋给表格的值(tableData),依次展开或收起每一行

在这里插入图片描述

forArr(arr, isExpand) {
  arr.forEach(i => {
    this.$refs.theTable.toggleRowExpansion(i, isExpand)
    if (i.children) {
      this.forArr(i.children, isExpand)
    }
  })
},
expandAll() { // 默认展开全部的话,首次加载需要在$nextTick下进行
  this.forArr(this.tableData, true)
},
collapseAll() {
  this.forArr(this.tableData, false)
}

完整案例

<template>
<el-table :data="tableData" row-key="id" class="table" ref="table">
          <el-table-column prop="resourceName" label="资源名称" align="center">
          </el-table-column>
          <el-table-column prop="resourceType" label="资源类型" align="center">
          </el-table-column>
          <el-table-column prop="order" label="显示顺序" align="center">
          </el-table-column>
          <el-table-column label="状态" align="center">
            <template slot-scope="scope">
              <span :class="scope.row.status ? 'typeActive' : ''">{{
                scope.row.status ? "启用中" : "已停用"
              }}</span>
            </template>
          </el-table-column>
          <el-table-column label="操作" align="center">
            <template slot-scope="scope">
              <el-button
                @click="addResource(scope.row)"
                type="text"
                size="small"
                >新增</el-button
              >
              <el-button
                @click="updateHandle(scope.row)"
                type="text"
                size="small"
                >修改</el-button
              >
              <el-button
                type="text"
                size="small"
                @click="deleteHandle(scope.row)"
                >删除</el-button
              >
              <el-button type="text" size="small" @click="blockUp(scope.row)">{{
                scope.row.enabledFlag ? "停用" : "启用"
              }}</el-button>
            </template>
          </el-table-column>
        </el-table>
</template>
<script>
 export default {
   data(){
    return {
     tableData:[]//表格数据
  }
},
methods:{
// 遍历表格数据
    forTableData(arr,isExpand){
        arr.forEach(i =>{
            this.$refs.table.toggleRowExpansion(i,isExpand);
            if(i.children){
                this.forTableData(i.children,isExpand)
            }
        })
    },
    //展开
    expand() {
        this.forTableData(this.tableData,true)
    },
    // 收起
    packUp() {
        this.forTableData(this.tableData,false)
    },
}
}
</script>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值