el-tree 懒加载的情况下,默认展开2级

这篇博客主要介绍了在使用Element UI的El-Tree组件时,如何通过设置`node-key`和`default-expanded-keys`属性来实现自定义默认展开的节点。通过设置`node-key`为每个树节点的唯一标识,如`id`,并创建一个数组`treeData`存储默认展开节点的key,在获取树状数据时动态更新`treeData`,从而达到控制默认展开效果的目的。

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

官方default-expand-all是否默认展开所有节点,没法自定展开我们想要的效果。

解决方案:

        1、设置node-key属性,每个树节点用来作为唯一标识的属性,整棵树应该是唯一的。例如:node-key="id";

2、设置default-expanded-keys属性,默认展开的节点的 key 的数组;

贴上代码:

1)页面元素代码

<el-tree
          :load="loadNode"
          node-key="id"
          lazy
          :default-expanded-keys="treeData"
          :data="deptOptions"
          :props="defaultProps"
          :expand-on-click-node="false"
          :filter-node-method="filterNode"
          ref="tree"
          :default-expand-all="false"
          @node-click="handleNodeClick"
        >

2)在自己的数据结构中定义了一个数组treeData用于存放默认展开的节点的 key 的数组

 data() {
    return {   
      treeData: [],  

3)在获取树状数据:data="deptOptions"的地方给treeData赋值

loadNode(node, resolve) {
      this.nowSelectNodeId = node.key || 0;
      treeselect1(node.key || 0).then(response => {
        resolve(response.data);
        if (response.data.length == 1) {          
          response.data.forEach(element => {
            this.treeData.push(element.id)
          });
        }
      });
    },

重点:

        1、设置 node-key="id";:default-expanded-keys="treeData";

        2、在获取树状数据的时候,给treeData赋值

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值