vue中echarts点击事件点击一次多次触发

前言:

        vue中使用echarts图,并且使用他的点击事件就会发现一个问题,第一次我echarts图的点击事件是生效的而且正常的,但是一旦重新渲染这个echarts图以后,就会出现再重新渲染一次,(相当于2次渲染echarts图),点击事件会被调用2次,第二次重新渲染,点击事件就会被调用3次,这个问题。

问题展示:(我这里是调用后台,我的日历刷新一次时间,就会重新渲染一次我的echarts图)

正常点击事件(前,点击一次调用一次后台):

异常(当我选了日历以后,重新渲染echarts图,再点击的时候,重新渲染几次,点击多几次)

解决办法:

再渲染echarts图前加:  this.myChart.off('click') // 这里很重要!!解决重复点击

this.myChart = echarts.init(this.$refs.chart);
          this.myChart.off('click') // 这里很重要!!解决重复点击
          this.myChart.setOption({

封装组件源码:

<template>
  <div class="echarts" ref="chart"></div>
</template>

<script>
  const echarts = require('echarts');
  export default {
    props:{
      data:{//echarts数据
        type:Array,
        default:()=>[]
      },
      Params:Object,
    },
    data () {
      return {
        name:'柱图',
        myChart:null,
      };
    },
    components: {},
    mounted() {
      this.initCharts(this.data);
    },
    watch:{
      data(val){
          this.initCharts(val);
      }
    },

    methods: {
      initCharts(data){
        if(data.length==0){
          return;
        }
        let unit = this.Params.unit;//单位
        /**
         * 处理数据
         */
        // let dataAxis = ['10.24', '10.25', '10.26', '10.27', '10.28', '10.29', '今日'];
        // let Ydata =  [220, 182, 191, 234, 290, 330, 310];
        let dataAxis = [];
        let Ydata = [];
        data.forEach(item => {
          dataAxis.push(item.date);//日期
          Ydata.push(item.value);//积分
        });
        let maxLengthVal = Ydata.length-1;

        /**
         * 获取数据内部最大值,+100来设置背景图高度
         */
        var max = Ydata.reduce( (a,b)=> b > a ? b : a );//获取最大值
        var dataShadow = [];
        var yMax;
        if(max<100){
          yMax = max+30;
        }else if(max>100 && max<500){
          yMax = max+100;
        }else{
           yMax = max+200;
        }
        for (var i = 0; i < Ydata.length; i++) {
            dataShadow.push(yMax);
        }

          this.myChart = echarts.init(this.$refs.chart);
          this.myChart.off('click') // 这里很重要!!解决重复点击
          this.myChart.setOption({
              xAxis: {
                  data: dataAxis,
                  axisLabel: {
                      inside: true,
                      textStyle: {
                          color: '#000',
                          fontSize:'100%'
                      }
                  },
                  axisTick: {
                      show: false
                  },
                  axisLine: {
                      show: false
                  },
                  position: "top",
                  z:10

              },
              yAxis: {
                  axisLine: {
                      show: false
                  },
                  axisTick: {
                      show: false
                  },
                  axisLabel: {
                       show: false
                  },
                  splitLine:{//网格线
                    show:false
                 }
              },
              dataZoom: [
                  {
                      type: 'inside'
                  }
              ],
              series: [
                  { // For shadow
                      type: 'bar',
                      itemStyle: {
                          normal: {color: '#F6FBFE'},
                          emphasis: {color: 'rgba(255,188,117,.3)'}
                      },
                      barGap:'-100%',
                      barCategoryGap:'40%',
                      data: dataShadow,
                      animation: false
                  },
                  {
                      type: 'bar',
                      label: {
                          normal: {
                              show: true,
                              position: 'top',
                              color:'#000',
                              fontSize:'100%',
                              formatter: function (params) {
                                  return params.value+unit;
                              },
                          },
                      },
                      itemStyle: {
                          normal: {
                              // color: new echarts.graphic.LinearGradient(
                              //     0, 0, 0, 1,
                              //     [
                              //         {offset: 0, color: '#FF3405'},
                              //         {offset: 0.5, color: '#FF6A47'},
                              //         {offset: 1, color: '#FF9076'}
                              //     ]
                              // )
                              color: function(params) {
                                        if(params.dataIndex == maxLengthVal){
                                          return new echarts.graphic.LinearGradient(
                                              0, 0, 0, 1,
                                              [
                                                  {offset: 0, color: '#FF3405'},
                                                  {offset: 0.5, color: '#FF6A47'},
                                                  {offset: 1, color: '#FF9076'}
                                              ]
                                          );
                                        };
                                        return  new echarts.graphic.LinearGradient(
                                              0, 0, 0, 1,
                                              [
                                                  {offset: 0, color: '#FFBD77'},
                                                  {offset: 0.5, color: '#FF9F38'},
                                                  {offset: 1, color: '#FF8505'}
                                              ]
                                          );
                                    }
                          },
                          emphasis: {
                              color: new echarts.graphic.LinearGradient(
                                  0, 0, 0, 1,
                                  [
                                      {offset: 0, color: '#FF3405'},
                                      {offset: 0.5, color: '#FF6A47'},
                                      {offset: 1, color: '#FF9076'}
                                  ]
                              )
                          }
                      },
                      data: Ydata
                  }
              ]

           })
        this.myChart.on('click',(params)=>{
             let name = '';
             data.forEach(item=>{
               if(item.date == params.name){
                 name = item.dateYear
               }
             })
              this.$emit('echartsClick',name);
           });
      },

    },
  }

</script>
<style lang='less' scoped>
  .echarts{
    width: 100%;
    height:100%;
  }
</style>

 

 

  • 10
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论
Vue,可以通过使用echarts原生提供的API来实现柱状点击事件。首先,在配置好echarts之后,需要绑定相应的事件。可以在echarts的配置添加以下代码来实现柱状点击事件: ``` myChart.on('click', function (params) { // 在这里编写处理点击事件的代码 }); ``` 在这个事件处理函数,`params`是echarts的事件处理函数自带的参数,它包含了本次触发对象的所有相关参数。你可以通过`params`来获取当前点击对象的信息,例如获取当前点击对象的名称: ``` myChart.on('click', function (params) { alert(params.data.name); // 当前点击对象的name }); ``` 这样,当用户在柱状点击时,就会触发点击事件,并弹出当前点击对象的名称。你可以根据具体的需求在事件处理函数编写相应的代码来处理点击事件。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [vue -- echarts/柱状添加点击事件](https://blog.csdn.net/weixin_44412840/article/details/121335083)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [(vue面试题)如何在Vue.js使用Vuex管理状态?请简述其核心概念包含代码.txt](https://download.csdn.net/download/weixin_44609920/88229888)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

浩星

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值