element plus 可选择树形组件(el-tree) 怎样一键展开/收起?实现方法详解

实现代码:

按钮:


    {{zhanstatus % 2 != 0 ? "收起所有" : "展开所有"}}

组件:

        
          
        

 在ref中绑定folderTreeRef 

展开&收起:

const folderTreeRef = ref(null);
const zhanstatus = ref(0);
let takeall = () => {
  zhanstatus.value++;
  if (zhanstatus.value % 2 == 0) {
    const nodes = folderTreeRef.value.store._getAllNodes();
    nodes.forEach(item => {
      item.expanded = false;
    });
  } else {
    const nodes = folderTreeRef.value.store._getAllNodes();
    nodes.forEach(item => {
      item.expanded = true;
    });
  }
};

效果:

element plus 可选择树形组件(el-tree) 怎样一键展开/收起?实现方法详解_第1张图片

实现原理:

打印上面的 folderTreeRef ,可以从原型链的store中找到 _getAllNodes 属性

element plus 可选择树形组件(el-tree) 怎样一键展开/收起?实现方法详解_第2张图片

element plus 可选择树形组件(el-tree) 怎样一键展开/收起?实现方法详解_第3张图片

官方文档好像没有描述关于此属性的内容,查了好多资料,搜了多篇文章,可以发现store原型中有_getAllNodes 这个属性

稍微试了一下居然成功了 (๑ᵒ̴̶̷͈᷄ᗨᵒ̴̶̷͈᷅)

你可能感兴趣的:(vue.js,前端,javascript,elementui)