echarts树图动态添加子节点

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

Apache ECharts 中文网

效果预览图:

目录

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

一,监听点击事件

[二 通过点击事件添加新的数据](#二 通过点击事件添加新的数据),


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

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

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

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

一,监听点击事件

//在初始化函数

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

javascript 复制代码
 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属性中。

完整函数如下

javascript 复制代码
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 });
      }
    },

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

相关推荐
moshuying1 天前
别让AI焦虑,偷走你本该有的底气
前端·人工智能
GIS之路1 天前
ArcPy,一个基于 Python 的 GIS 开发库简介
前端
可夫小子1 天前
OpenClaw基础-为什么会有两个端口
前端
喝拿铁写前端1 天前
Dify 构建 FE 工作流:前端团队可复用 AI 工作流实战
前端·人工智能
喝咖啡的女孩1 天前
React 合成事件系统
前端
从文处安1 天前
「九九八十一难」组合式函数到底有什么用?
前端·vue.js
前端Hardy1 天前
面试官:JS数组的常用方法有哪些?这篇总结让你面试稳了!
javascript·面试
用户5962585736061 天前
戴上AI眼镜逛花市——感受不一样的体验
前端
yuki_uix1 天前
Props、Context、EventBus、状态管理:组件通信方案选择指南
前端·javascript·react.js
老板我改不动了1 天前
前端面试复习指南【代码演示多多版】之——HTML
前端