echarts 加载动画重绘\自适应\toolbox中magicType的方法


前言

最近用了好多echarts,总结一下一些小功能,方便日后查看

一、加载动画重绘

代码如下:

this.ss = setInterval(()=>{
      
      var option1 = this.myChart.getOption();
      this.myChart.clear();  // 清空画布
      this.myChart.setOption(option1); // 重新绘制
    },3000)

二、自适应

代码如下:

// 这是浏览器窗口变化监听
window.addEventListener("resize", () => {
                            noiseLine.resize();
                        });
// 这是侧边栏变化监听。vue3,加setTimeout是因为侧边栏变化需要时间
watch(() => store.state.isCollapse, (newV, oldV) => {
        setTimeout(() => {
            lineChart.resize()
            barChart.resize()
            pieChart.resize()
        }, 30)

    })

三、toolbox中magicType的方法

在这里插入图片描述
第一个折线图、第二个柱状图、第三个刷新、第四个下载(下载是下载成图片,如果是别的文件的话,是要自己做下载的图标,然后绝对定位写入,再给他点击事件)
代码如下:

// 下载鼠标悬浮的样式
.xia-zai-tooltip.el-tooltip__popper.is-light {
  border:none;
  background-color: transparent;
  color:#29C984;
  padding: 0;
  margin-top: 7px;
  width: 25px;
}
// v-if="flag"这是因为如果图表没加载出来,单独写的下载按钮会出来,这是写在图表完成之后设为true,或者是数据拿到之后也可以,数据小选择的快
<el-tooltip
          v-if="flag"
          class="item"
          effect="light"
          content="下载"
          placement="bottom"
          :visible-arrow='false'
          popper-class='xia-zai-tooltip'
        >
          <div class="iconfont iconfont-xiazai xia-zai" @click.stop="onExport"></div>
        </el-tooltip>
// 渲染完成之后的方法
noiseLine.on('finished', function () {
    this.flag = true
});

// 点击折线图、或者柱状图都要能下载,所以下载的参数不一样
noiseLine.on('magictypechanged', (params) => {
                            if (params.currentType == 'line') {
                                this.chartType = '2'
                            } else if (params.currentType == 'bar') {
                                this.chartType = '1'
                            }
                        })
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值