登录
首页 >  文章 >  前端

Vue3中echarts无法缩放如何解决

来源:亿速云

时间:2024-04-16 08:45:24 446浏览 收藏

在文章实战开发的过程中,我们经常会遇到一些这样那样的问题,然后要卡好半天,等问题解决了才发现原来一些细节知识点还是没有掌握好。今天golang学习网就整理分享《Vue3中echarts无法缩放如何解决》,聊聊,希望可以帮助到正在努力赚钱的你。

问题描述

官网示例正常

1、打开echarts官网示例:https://echarts.apache.org/examples/zh/editor.html?c=area-rainfall
这个示例的缩放功能是正常的。如下图:

Vue3中echarts无法缩放如何解决

官网示例在本地缩放异常

把上面这个demo的option复制到本地环境,运行效果:初始渲染正常,拖动缩放把手就报js错误。如下图:

Vue3中echarts无法缩放如何解决

点击进入错误堆栈,发现报seriesModel的coordinateSystem这个属性为undefined

Vue3中echarts无法缩放如何解决

开始以为是echarts版本与官网的版本不一致引起,结果更新本机的echarts跟官网的echarts版本一致。下载官网的echarts跟本机的echarts进行文件比对,发现一模一样。

灵光乍现


重点就是两句话,如下图:

Vue3中echarts无法缩放如何解决

问题解决

找到解题思路之后修改代码,由于我的代码是vue2升级到vue3。vue2的版本中myChart对象是放在data里面的,升级到vue3只是简单的代码改写,myChart仍然放在data里面。代码如下:

const data = ref({
dataDriver: null,
chartConfig: null,
myChart: null
});

vue3中ref绑定的对象都是响应式的对象,对象中的属性值变动都经过vue3的proxy拦截处理。
因此如果是跟页面内容进行响应式绑定的值应该放在data里面,而我的图表用的是原生的echarts api自己绘制的,因此不需要做响应式绑定,如果绘制图表的数据发生变化,我自己会手工调用echarts进行重绘。因此我只需要把myChart从data中删除放到外面即可。如下图:

Vue3中echarts无法缩放如何解决

今天关于《Vue3中echarts无法缩放如何解决》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于Vue3,echarts的内容请关注golang学习网公众号!

声明:本文转载于:亿速云 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>