Vue中echarts的图表自适应屏幕宽度及resize错误

#实现自适应

Echarts 图表并不会随着窗口的变化而变化,需要你主动的去绑定resize()事件来达到自适应的效果。解决方法:

1.window.onresize = this.$refs.myChart.resize;//自己设置ref属性绑定元素

2.window.addEventListener("resize", () => {
      if (this.$refs.myChart) this.$refs.myChart.resize();//自己设置ref属性绑定元素
      if (this.$refs.myChart2) this.$refs.myChart2.resize();
      if (this.$refs.myChart3) this.$refs.myChart3.resize();
    });
  },

一个页面有多个表格的话,需要用第二种方法。

#resize报错

在使用resize()后,当 屏幕变化的时候报:Uncaught TypeError: Cannot read property of undefined (reading ‘resize’ )

解决前代码:

  window.addEventListener("resize", () => {
      this.$refs.myChart.resize();
      this.$refs.myChart2.resize();
      this.$refs.myChart3.resize();
    });

解决后代码:

window.addEventListener("resize", () => {
      // 先判断,再调用resize方法
      if (this.$refs.myChart) this.$refs.myChart.resize();
      if (this.$refs.myChart2) this.$refs.myChart2.resize();
      if (this.$refs.myChart3) this.$refs.myChart3.resize();
    });

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值