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 });
      }
    },

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

相关推荐
xiaotao1313 小时前
第九章:Vite API 参考手册
前端·vite·前端打包
午安~婉4 小时前
Electron桌面应用聊天(续)
前端·javascript·electron
彧翎Pro4 小时前
基于 RO1 noetic 配置 robosense Helios 32(速腾) & xsense mti 300
前端·jvm
小码哥_常4 小时前
解锁系统设置新姿势:Activity嵌入全解析
前端
之歆5 小时前
前端存储方案对比:Cookie-Session-LocalStorage-IndexedDB
前端
哟哟耶耶5 小时前
vue3-单文件组件css功能(:deep,:slotted,:global,useCssModule,v-bind)
前端·javascript·css
是罐装可乐5 小时前
深入理解“句柄(Handle)“:从浏览器安全到文件系统访问
前端·javascript·安全
华科易迅5 小时前
Vue如何集成封装Axios
前端·javascript·vue.js
康一夏5 小时前
Next.js 13变化有多大?
前端·react·nextjs
糖炒栗子03265 小时前
前端项目标准环境搭建与启动
前端