项目中有需求,需重新定义echarts的提示tooltips,里面有个formatter属性,可重新定义提示内容

在项目中遇到Echarts的tooltips提示需求,通过设置formatter属性能实现自定义提示内容。然而,在使用Vue时,需要注意在formatter内部绑定this上下文,通常需要使用`_this = this`来确保能访问到Vue实例。尽管如此,仍可能出现无法预期的问题,目前原因不明。

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

<template>
   <div class="echarts">
        <div id="mychart" style="width: 100%; height: 420px;"></div>
      </div>
</template>
<script>
  methods:{
   //初始化echart
      initChart() {
        let _this = this
        let chart = this.$echarts.init(document.getElementById('mychart'));
        chart.setOption({
          tooltip: {
            trigger: 'item',
            formatter: function (params) {
              let name = params.name
              let radarList = _this.radarData
              for (let i = 0; i < params.data.value.length; i++) {
                name += '<br/>' + radarList[i]['name'] + ' : ' + '最大值' + radarList[i]['max'] + ',当前值'
                  + params.data.value[i];
              }
              return name;
            }
          },
          grid: {
            left: '1%',
            right: '2%',
            bottom: '3%',
            containLabel: true
          },
          radar: {
            name: {
              textStyle: {
                color: '#fff',
                borderRadius: 3,
              }
            },
            indicator: this.radarData,
          },
          series: [{
            name: this.radarName,
            type: 'radar',
            areaStyle: {
              color: "#5fb89f",
            },
            data: [
              {
                value: this.valueData,
                name: this.radarName
              },
            ]
          }]
        })
      },
}
</script>

在这里插入图片描述
里面的formatter属性可以拿到值后重新定义,this.radarData中的this不能取到vue实例,需_this = this
才可以取到值,虽然获取到了值,但是不知道什么原因

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值