关于vue3+echart5 遇到的坑 Cannot read properties of undefined reading 'type'

目录
  • 1、错误说明
  • 2、错误原因
  • 3、解决方案

1、错误说明

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

export default {
  data) {
    return {
      chart: null,
      ...
    }
  },
  mounted) {
    this.chart = echarts.initdocument.getElementByIdthis.id))
    this.chart.setOption{...})
  },
  ...
}

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

2、错误原因

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

coordSys.type

3、解决方案

参考官方:

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

  • 有些值不应该是响应式的,例如复杂的第三方类实例或 Vue 组件对象。
  • 当渲染具有不可变数据源的大列表时,跳过 proxy 转换可以提高性能。

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

import { markRaw } from 'vue'
this.chart = markRawecharts.initdocument.getElementByIdthis.id)))

随着vue3.2版本的发布以及setup语法的出现,这些已经都不是问题啦,赞美vue

到此这篇关于vue3+echart5 遇到的坑 Cannot read properties of undefined reading 'type')的文章就介绍到这了,更多相关vue3报错Cannot read properties of undefined内容请搜索风君子博客以前的文章或继续浏览下面的相关文章希望大家以后多多支持风君子博客!

您可能感兴趣的文章:

  • vue3.0报错Cannot find module‘worker_threads‘的解决办法
  • 完美解决vue中报错 “TypeError: Cannot read properties of null reading'forEach')“
  • web前端Vue报错:Uncaught in promise) TypeError:Cannot read properties of nu解决

Published by

风君子

独自遨游何稽首 揭天掀地慰生平

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注