首页 > 其他分享 >elementUI 如何动态的给 el-tree 添加子节点数据 children

elementUI 如何动态的给 el-tree 添加子节点数据 children

时间:2022-10-16 21:32:59浏览次数:54  
标签:el elementUI tree 节点 点击 nodeData id 加载


elementUI 如何动态的给 el-tree 添加子节点数据 children

一、需求

有这样一个数据结构的 tree。

elementUI 如何动态的给 el-tree 添加子节点数据 children_懒加载


​element​​ 的 tree 懒加载是从根上就开始懒加载,但我需要实现的是已经存在一个层级的 tree 结构,只是在末端点击的时候,载入末端以下的列表。

二、实现

1. tree 的实例事件 ​​node-click​

我们就不能用它的懒加载方法了,而是使用 ​​node-click​​ 这个事件

<el-tree
ref="treeNav"
:indent="10"
:default-expanded-keys="defaultExpandedKeys"
@node-click="treeNodeClicked"
:data="treeData"
:highlight-current="true"
node-key="id">
</el-tree>

当点击的事件说明:

elementUI 如何动态的给 el-tree 添加子节点数据 children_elementui_02

点击的时候你获取到了:当前被点击节点的完整数据,你只需要

  1. 用其中的​​id​​ 或者其它自己定义的标识字段,去获取对应的数据
  2. 然后再格式化成​​tree​​ 的数据
  3. 重新赋值给当前节点的​​children​​ 字段即可

2. tree 的实例方法:​​updateKeyChildren​

此时你还需要用到 tree 的另一个方法: ​​updateKeyChildren​​。

其作用的就是根据你提供的节点的 ​​id​​​,设置这个节点的 ​​children​​ 数据,刚好是要用到的。

elementUI 如何动态的给 el-tree 添加子节点数据 children_vue.js_03

3. 自动展示当前被点击的节点

点击并插入当前节点的 ​​children​​ 数据之后,需要它自动展开

只需要设置 ​​tree​​​ 参数中的 ​​default-expanded-keys​​​ 为当前节点的 ​​key​​ 即可

this.defaultExpandedKeys = [nodeData.id]

4. 页面重新加载后,定位到当前的位置

页面的 url 参数中保留几个参数: ​​projectid​​​ ​​devicename​​​ ​​index​

  1. 页面重载之后,用 projectid 来获取内部数据
  2. 添加到已有的树结构中
  3. 再使用 tree 组件的 setCurrentNode(nodeKey) 方法来选中该选中的节点

当然,这个实现过程还是有点繁琐的。

页面重新刷新,其结果就是:

elementUI 如何动态的给 el-tree 添加子节点数据 children_vue.js_04

// 存在 projectId 时,加载对应项目的 preview 信息,并定位到之前的设备位置
if (this.currentProjectId){
this.getProjectPreviewOf(this.currentProjectId, projectPreview => {
let checkedKey = `project-${this.currentProjectId}:${this.deviceName}`
this.$refs.treeNav.setCurrentKey(checkedKey)
this.SET_CURRENT_DEVICE_LIST(projectPreview[this.deviceName])
})
}

5. 参考代码

// 根据 projectId 获取对应项目的 preview
getProjectPreviewOf(nodeData){
areaApi
.previewOfProject({
pid: nodeData.projectInfo.id
})
.then(res => {
let treeDataForPreview = this.getTreeDataFromPreview(res, nodeData.projectInfo.id)
console.log('Tree data for preview: ',treeDataForPreview)
this.$refs.treeNav.updateKeyChildren(nodeData.id, treeDataForPreview)
// 展开当前节点
this.defaultExpandedKeys = [nodeData.id]
// 默认展示:当前项目的第一个设备类型的设备
this.SET_CURRENT_DEVICE_LIST(treeDataForPreview[0].deviceInfos)
})
},

三、结果

elementUI 如何动态的给 el-tree 添加子节点数据 children_elementui_05


标签:el,elementUI,tree,节点,点击,nodeData,id,加载
From: https://blog.51cto.com/kylebing/5760554

相关文章

  • 7-shell脚本编程
    内容脚本基础格式变量运算条件测试配置用户环境流程控制函数脚本工具数组字符串处理高级变量--------------------------------正文--------------------------------------......
  • shell脚本检查tomcat应用健康状态
    1.首先应用编写一个接口(http均可)接口查询数据库中随便一个表一条数据,正常返回数据这表示应用健康,否则应用运行异常。@RequestMapping(value="/heartbeat",method=R......
  • Element-UI的基本使用
    Element-UI:一套基于2.0的桌面端组件库官网地址:http://element-cn.eleme.io/#/zh-CN基于命令行方式安装:A.安装:npminstallelement-ui-S-S上线环境也需......
  • PLSQL Developer 14软件安装包下载及安装教程
    PLSQLDeveloper14软件简介:PLSQLDeveloper14是款编程行业常使用的PL/SQL数据库管理工具。PLSQLDeveloper正式版具有语法加强、SQL和PL/SQL帮助、对象描述、代码助手、编......
  • wpf: StackPanel和WrapPanel
    他们是垂直面板和水平面板 StackPanel是默认垂直的,而且受到设定的宽度和高度影像,不管是Orientation为Horizontal还是vertical超过预设值的大小就会不显示,并不会换行 ......
  • iCells(Excel插件)第一个版本正式发布
    一、界面二、功能(一)支持连续撤销,由于时间有限,未能开发全部的撤销功能,后期将逐步加入。(二)多种号码校验,特别是身份证校验,对于身份证录入后的校验简直是神器。(三)随机功能......
  • JRebel 的使用
    什么是JRebel?JRebel是一套JavaEE开发工具。Jrebel可快速实现热部署,节省了大量重启时间,提高了个人开发效率。JRebel是一款JAVA虚拟机插件,它使得JAVA程序员能在不进行重......
  • Spring Boot:自定义 Whitelabel 错误页面
    一、概述在本文中,我们将研究如何禁用和自定义SpringBoot应用程序的默认错误页面,因为正确的错误处理描述了专业性和质量工作。2.禁用白标错误页面首先,让我们看看如何通......
  • 外向交货单发货过账BAPI:BAPI_OUTB_DELIVERY_CONFIRM_DEC
    前面说过,可以使用 WS_DELIVERY_UPDATE进行外向交货单的发货过账,当然,这个可实现的很多,过账,冲销,删除都可以但是这个不是bapi,是个函数,则会缺少bapi自带的那些校验为了更安全,其......
  • 删除外向交货单 BAPI_OUTB_DELIVERY_CHANGE
    删除外向交货单是没有直接以delete结尾的bapi的,是使用的change:BAPI_OUTB_DELIVERY_CHANGE已经过账的交货单应该是先冲销,再删除,这里暂时不写了。仅考虑没过帐的交货单。一般......