首页 前端知识 echarts树图动态添加子节点

echarts树图动态添加子节点

2025-02-25 13:02:13 前端知识 前端哥 564 537 我要收藏

宝子们,echarts原官网很卡,我建议直接看这个中文ecahrts网站

Apache ECharts 中文网

效果预览图:

目录

动态添加子节点流程和思路:

一,监听点击事件

二 通过点击事件添加新的数据,


动态添加子节点流程和思路:

1.在初始化函数中监听echarts树图的点击事件,通过点击可以拿到当前节点的节点数据,这个节点数据是一个对象。

2.这个节点数据改变当前图标实例的数据也会改变,但是视图没有发生变化,需要我们调用setoption刷新视图。我们通过点击事件拿到的节点数据,通过发起请求拿到后端接口给的数据,使用push函数(我用的vue2,所以要用push,vue3的只要能添加到children中什么方法都可以)添加到节点数据的.data.children属性中(树图子节点默认是children属性)。

3.调用setoption方法更新视图。

一,监听点击事件

//在初始化函数

中初始图标并监听点击事件

initChart() {
// .....
//是否需要重新init
if (this.chart == null) {
this.chart = echarts.init(document.getElementById('chart'));
}
this.chart = echarts.getInstanceByDom(document.getElementById('chart'));
//setoption函数
this.chart.setOption({
///.....
});
//调用哲哲函数先用off清除了全部的监听事件
this.chart.off();
//监听点击事件
this.chart.on("click", (params) => {
this.chartClick(params);
});
},
//点击事件
chartClick(params){
//函数逻辑
...
}
复制

通过树图实例的.on事件绑定了一个点击事件,这时候点击树节点就会触发 chartClick点击事件

二 通过点击事件添加新的数据,并更新视图

首先,点击事件要做一个判断,如果点击的节点没有子节点了,我们就加载数据,如果有子节点了,我们要让他收起来。

基于这个判断,通过点击事件传递的参数,也是绑定.on事件时树图实例拿到的参数,可以看到如下

点击图中的生物多样性节点,可以拿到此时的节点信息,从而可以根据拿到的节点数据,发起接口请求拿到数据,添加到 图中的data属性下的children属性中。

完整函数如下

chartClick(item) {
//如果节点有子节点,则不是叶子节点不需要加载数据
if (item.data.children) {
return;
} else {
let addList=[]
//....接口获取数据步骤
//将要添加的数据添加到addlist中,之后循环加到当前节点的数据中
//给当前子节点添加children属性
this.$set(item.data, "children", []);
//循环添加子节点
addList.forEach((v) => {
item.data.children.push({
name: v.name,
value: v.id,
desc: v.knowledgeTitle,
});
});
//获取添加后数据的实例的对象,调用setoptions更新树图
let series = this.chart._model.option.series;
this.chart.setOption({ series: series });
}
},
复制

这样就可以实现动态添加子节点的功能,代码经过删减,但是实现思路是这样,可以改写代码以达到自己想实现的功能。

转载请注明出处或者链接地址:https://www.qianduange.cn//article/21450.html
标签
评论
发布的文章

python调用ollama库详解

2025-02-25 13:02:30

大家推荐的文章
会员中心 联系我 留言建议 回顶部
复制成功!