2023vue3+echart5遇到的坑Cannot read properties of undefined (reading 'type')怎么解决

 所属分类:web前端开发

 浏览:114次-  评论: 0次-  更新时间:2023-05-12
描述:更多教程资料进入php教程获得。 1、错误说明vue3中,使用data的方式初始化echart图表export default { data() { return { ...
更多教程资料进入php教程获得。

1、错误说明

vue3中,使用data的方式初始化echart图表

export default {
  data() {
    return {
      chart: null,
      ...
    }
  },
  mounted() {
    this.chart = echarts.init(document.getElementById(this.id))
    this.chart.setOption({...})
  },
  ...
}
登录后复制

在窗口大小发生变化时,需要执行this.chart.resize()动态调整图表的大小,发生错误:

vue3+echart5遇到的坑Cannot read properties of undefined (reading 'type')怎么解决

2、错误原因

vue3中使用proxy的方式监听响应式,this.chart会被在vue内部转换成响应式对象,从而在resize 的时候获取不到

coordSys.type
登录后复制

3、解决方案

参考官方:

你可以有选择地退出默认的深度响应式/只读转换模式,并将原始的,未被代理的对象嵌入状态图中。它们可以根据情况灵活运用:

  • 有些值不应该是响应式的,例如复杂的第三方类实例或 Vue 组件对象。

  • 当渲染具有不可变数据源的大列表时,跳过 proxy 转换可以提高性能。

所以在实例化echart时,将其指定为非响应式的即可。

import { markRaw } from 'vue'
this.chart = markRaw(echarts.init(document.getElementById(this.id)))
登录后复制

以上就是vue3+echart5遇到的坑Cannot read properties of undefined (reading 'type')怎么解决的详细内容,更多请关注zzsucai.com其它相关文章!

 标签: vue3,
积分说明:注册即送10金币,每日签到可获得更多金币,成为VIP会员可免金币下载! 充值积分充值会员更多说明»

讨论这个素材(0)回答他人问题或分享使用心得奖励金币

〒_〒 居然一个评论都没有……

表情  文明上网,理性发言!