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