el-table树状表格,默认展开第一个节点的每一层

效果如图

复制代码
<template>
  <el-table
    :data="tableData"
    style="width: 100%"
    :tree-props="{ children: 'children', hasChildren: 'hasChildren' }"
    :expand-row-keys="expandRowKeys"
    row-key="id"
    @expand-change="handleExpandChange"
  >
    <el-table-column
      prop="name"
      label="名称"
      width="180"
    ></el-table-column>
    <el-table-column
      prop="value"
      label="值"
    ></el-table-column>
  </el-table>
</template>

<script>
export default {
  data() {
    return {
      tableData: [
        {
          id: 1,
          name: "一级1",
          value: "A",
          children: [
            {
              id: 2,
              name: "二级1-1",
              value: "A-1",
              children: [
                { id: 3, name: "三级1-1-1", value: "A-1-1" },
                { id: 4, name: "三级1-1-2", value: "A-1-2" }
              ]
            },
            {
              id: 5,
              name: "二级1-2",
              value: "A-2",
              children: [
                { id: 6, name: "三级1-2-1", value: "A-2-1" }
              ]
            }
          ]
        },
        {
          id: 7,
          name: "一级2",
          value: "B",
          children: [
            {
              id: 8,
              name: "二级2-1",
              value: "B-1",
              children: [
                { id: 9, name: "三级2-1-1", value: "B-1-1" }
              ]
            }
          ]
        }
      ],
      expandRowKeys: [], // 保存展开的行的key
    };
  },
  methods: {
    // 递归函数来获取每层的第一个节点id 
   
    getFirstNodeKeys(data) {
      let keys = [];
      data.forEach(item => {
        keys.push(item.id); // 添加当前节点的id
        if (item.children && item.children.length) {
          keys = keys.concat(this.getFirstNodeKeys(item.children)); // 递归获取子节点的第一个
        }
      });
      return keys;
    },
    // 处理展开行的变化
    handleExpandChange(row, expandedRows) {
      // 可选处理扩展展开事件
    }
  },
  created() {
    // 初始化时设置默认展开每一层第一个节点
     // 注意!!!展开节点id数组必须是字符串的
    this.expandRowKeys = this.getFirstNodeKeys(this.tableData);
  }
};
</script>

<style scoped>
</style>
相关推荐
qq_12498707533 小时前
基于springboot的会议室预订系统设计与实现(源码+论文+部署+安装)
java·vue.js·spring boot·后端·信息可视化·毕业设计·计算机毕业设计
萧曵 丶3 小时前
JavaScript 函数各种写法和场景
开发语言·javascript·ecmascript
Yolanda944 小时前
【项目经验】钉钉免密登录实现
前端·javascript·钉钉
摘星编程4 小时前
在OpenHarmony上用React Native:collapsable节点优化策略
javascript·react native·react.js
ttod_qzstudio4 小时前
Vue 3 中 toRaw 的取舍之道:以 Babylon.js 3D 开发为例
vue.js·babylonjs
Beginner x_u4 小时前
JavaScript 原型、原型链与原型继承的核心机制解析
开发语言·javascript·原型模式·原型原型链
Mr Xu_5 小时前
Vue3 + Element Plus 实战:App 版本管理后台——动态生成下载二维码与封装文件上传
前端·javascript·vue.js
比特森林探险记5 小时前
Vue基础语法与响应式系统详解
前端·javascript·vue.js
2601_949847755 小时前
Flutter for OpenHarmony 剧本杀组队App实战:邀请好友功能实现
开发语言·javascript·flutter
FITA阿泽要努力5 小时前
Agent Engineer-Day 1 初始智能体与大语言模型基础
java·前端·javascript