学无先后,达者为师

网站首页 前端文档 正文

vue3.0 中使用echarts图 tooltip 不显示的问题

作者:前端.攻城狮 更新时间: 2021-12-24 前端文档

问题: 由于我需要在后台数据还没请求回来时,在echarts图上加个加载图标,所以定义了一个 全局变量来接收echarts 实例。
之后就发现 option配置了 trigger: ‘axis’, 但是 tooltip 显示不出来

 tooltip: {
     trigger: 'axis'
 }, 

请添加图片描述

// 定义了一个全局的响应式变量,用于接收echarts实例
const myChart = ref()

onMounted(() => {
  myChart.value = echarts.init(myLine.value as HTMLElement)
  myChart.value.showLoading()
  myChart.value.setOption(option.value, true)
  
  watch(loading, () => {
    if (loading.value) {
		myChart.value.showLoading()
	} else {
		myChart.value.hideLoading()
	}
  })
})

通过查阅资料,是因为 echarts 实例赋值给 ref 响应式 Proxy对象,导致tooltip不显示

解决办法:要用普通变量来接收 echarts 实例

// 定义普通变量来接收实例
let myChart:any

onMounted(() => {
  myChart= echarts.init(myLine.value as HTMLElement)
  myChart.showLoading()
  myChart.setOption(option.value, true)
  
  watch(loading, () => {
    if (loading.value) {
		myChart.showLoading()
	} else {
		myChart.hideLoading()
	}
  })
})

请添加图片描述
搞定!!!

原文链接:https://blog.csdn.net/weixin_45304198/article/details/122115316

栏目分类
最近更新