一键解决tab切换(VUE中el-tabs切换)echarts无法显示的问题

前言

最近刚好项目里需要用到tab切换显示echarts,也同样出现了图表总是刷不出来的问题。对于这个问题我也是翻看了很多资料哈,其实最后都不是我想要的效果之类的,比如说v-if之类的,话不多说直接上我自己的解决办法。

代码部分

原理就不多说了,翻找此问题多多少少都有知道了。
其实,每次tab切换时我们只需要重新获取到该标签,然后调用一下resize就行。
记住:该方法写在切换到指定页面的事件里面。以我的例子来说onViewShow就是在tab切换视图显示的事件里掉用echarts获取元素标签,然后resize()
获取标签

$$('chart).getNode() //实际就是获取该图表的标签

在VUE中使用el-tab切换的问题

问题还是那个老问题,这里就把代码附上
首先现有在有图表标签上新增一个ref名称,然后在el-tab的切换事件tab-click中使用该函数
前提是看你echarts是怎么引入的就用什么方法
比如 我这里引入直接是使用了echarts 所以建立图表和后续使用的方法都直接使用echarts

1. 记住echarts引入的名称,我这里名称是echarts,你们可以对应的找自己的
echarts引入名称

2. 写好el-tabs和echarts的容器标签

容器标签

3.在el-tabs事件tabChange里引用echarts的resize(),前面一定要加this.$nextTick哦
引用
这样echarts在el-tabs切换时图表显示不全或不显示的问题就解决了

最后,如果感觉有用,记得给个小心心哦!

  • 25
    点赞
  • 40
    收藏
    觉得还不错? 一键收藏
  • 27
    评论
评论 27
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值