官方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赋值

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐