echarts树图动态添加子节点

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

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

  • 7
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值