echarts dataZoom 组件报Cannot read properties of undefined (reading ‘type‘)

文章讲述了在Vue项目中使用ECharts库创建柱状图时,遇到dataZoom组件拖拽不生效的问题,通过将myChart变量改为var或let类型解决了控制台报错,并实现了图表的联动交互。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

需求要做一个可以拖拽范围的柱状图,效果如下,希望拖动滑块,柱状图联动交互。
在这里插入图片描述
我在使用dataZoom组件进行拖拽的时候,控制台报错,且拖动柱状图无反应。
在这里插入图片描述
查了一些资料,原因是我使用了this.myChart来接收数据,应该使用let或者var定义myChart,就不会出现错误了。
错误代码如下:

data() {
   
   
    return {
   
   
      myChart: null
    }
  },
  mounted() {
   
   
    this.initChart()
  },
  methods: {
   
   
    initChart() {
   
   
      this.myChart = echarts.init(document.getElementById('chart'));
      const option = this.formatBarOptions()
      this.myChart.setOption(option)
    },
    formatBarOptions () {
   
   
      const dataCount = 10;
      const data = this.generateData(dataCount);
      console.log(data)
      const option = {
   
   
        // title: {
   
   
        //   text: echarts.format.addCommas(dataCount) + ' Data',
        //   left: 10
        // },
        // toolbox: {
   
   
        //   feature: {
   
   
        //     dataZoom: {
   
   
        //       yAxisIndex: false
        //     },
        //     saveAsImage: {
   
   
        //       pixelRatio: 2
        //     }
        //   }
        // },
        tooltip: {
   
   
          trigger: 'axis',
          axisPointer: {
   
   
            type: 'shadow'
          }
        },
        grid: {
   
   
          top: 10,
          bottom: 90
        },
        dataZoom: [
          {
   
   
            type: 'slider',
            start: 10,
            end: 60,
            handleSize: 30, // 控制手柄的尺寸 number | string
            height: 15
### 解决 ECharts 中 `Uncaught TypeError: Cannot read properties of undefined (reading 'type')` 错误 当在 Vue3 环境中使用 ECharts 时,可能会遇到此错误。这通常是因为 ECharts 实例不是响应式的或者是由于组件卸载后仍然尝试访问已销毁的对象引起的。 #### 使用 `markRaw` 处理 ECharts 响应式问题 为了确保 ECharts 实例不会被 Vue 的响应式系统包裹而导致意外行为,在初始化 ECharts 实例之前应该将其标记为原始对象: ```javascript import { markRaw, ref } from 'vue'; import * as echarts from 'echarts'; const myChart = ref(null); onMounted(() => { // 初始化图表并使用 markRaw 来防止其成为响应式对象的一部分 myChart.value = markRaw(echarts.init(document.getElementById('main'))); }); ``` 这样可以避免因 Vue 尝试追踪变化而引发的问题[^3]。 #### 清除定时器和其他事件监听器 如果存在任何与图表关联的时间循环或交互事件,则应在组件销毁前清除这些绑定,以防止内存泄漏以及潜在的未定义属性访问异常: ```javascript let timerId; // 设置定时更新数据逻辑... clearInterval(timerId); timerId = null; if (myChart.value !== null && typeof myChart.value.dispose === 'function'){ myChart.value.dispose(); } ``` 上述代码片段展示了如何安全地清理资源,从而减少发生此类错误的可能性。 #### 检查 Legend 组件配置 对于特定于 legend 控件触发的情况,需确认选项设置是否正确无误。例如,确保传入的数据结构符合预期,并且所有必要的字段都已被正确定义: ```json { "legend": { "data":["shirt","cardigan"] }, ... } ``` 如果有自定义项或者动态生成的内容,请仔细验证这部分实现是否存在漏洞[^1]。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Sherry Tian

打赏1元鼓励作者

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值