【vue】vue封装echarts数据更新页面不重新渲染

本文介绍如何在Vue组件中使用ECharts,通过watch机制监控数据变化,确保图表实时响应父组件数据变动,实现动态渲染。

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

问题

在mounted中加载echart,在加载一次之后,父组件传过的数据变化,也不会再次引起渲染

解决思路

利用watch去监听数据的变化,当监听到变化时,让echarts去重新渲染

  props: {
    value1: Object,
    value2: Object,
    title: {
      type: String,
      default: ''
    },
    title1: {
      type: String,
      default: ''
    },
    title2: {
      type: String,
      default: ''
    }
  },
  mounted () {
    this.init()
  },
  watch: {
    value1: {
      handler () {
        this.init()
      },
      deep: true
    }
  },
  methods: {
    init () {
      const data1 = [this.value1.gpa, this.value1.gpa1, this.value1.gpa2, 5]
      const data2 = [this.value2.gpa, this.value2.gpa1, this.value2.gpa2, 5]
      const mychart = echarts.init(this.$refs.echart)
      const option = {
        title: {
          text: this.title
        },
        tooltip: {
          trigger: 'item'
        },
        legend: {
          data: [this.title1, this.title2]
        },
        radar: {
          indicator: [
            { name: '总绩点', max: 5 },
            { name: '高数上', max: 5 },
            { name: '高数下', max: 5 },
            { name: '其他、', max: 5 }
          ],
          radius: '60%'
        },
        series: [
          {
            name: 'Budget vs spending',
            type: 'radar',
            data: [
              {
                value: data1,
                name: this.title1
              },
              {
                value: data2,
                name: this.title2
              }
            ]
          }
        ]
      }
      mychart.setOption(option)
    }
  }
}
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Triumph-light

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值