ECHARTS:悬停在线时显示自定义工具提示

use*_*525 2 echarts

在带有线条和符号的标准简单折线图中,设置工具提示选项意味着每当您将鼠标悬停在符号上时,它都会显示一个包含线条名称和符号值的框。

我真正想要的是当我将鼠标悬停在线条本身上时显示此工具提示框(而不仅仅是当我将鼠标悬停在符号上时)。

另外,我希望此工具提示是一个自定义工具提示,仅包含行名称,并禁用符号。

A m*_*dev 5

要使悬停在线本身起作用,您必须设置triggerLineEventtrue

series: [
  {
    ... // your line serie config
    triggerLineEvent: true,
  },
Run Code Online (Sandbox Code Playgroud)

然后就可以使用Echart的鼠标事件来管理鼠标悬停在线条上:

var tooltipDisplay = ""

// Called when your mouse hover an object (params : the object you hover)
myChart.on('mouseover', function(params) {
  // Check if it's hovering a line
  if(params.componentSubType == "line"){
    // get hovered line series name
    tooltipDisplay = params.seriesName
  }
});

//Called when your mouse leaves an object (params : the object you leave)
myChart.on('mouseout', function(params) {
  tooltipDisplay = ''
});
Run Code Online (Sandbox Code Playgroud)

然后,将其显示在工具提示中:

tooltip: [
  {
    ... // your tooltip config
    formatter : (params) => {
      return tooltipDisplay;
    }
  },
Run Code Online (Sandbox Code Playgroud)

完整示例:

var myChart = echarts.init(document.getElementById('main'));

var tooltipDisplay = ""

option = {
  grid: {
     top: '10px',
     bottom: '40px',
     left: '100px',
     right: '100px',
  },
  tooltip: {
    trigger: 'axis',
    formatter : (params) => {
      return tooltipDisplay;
    }
  },
  xAxis: {
    type: 'category',
    boundaryGap: false,
    data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
  },
  yAxis: {
    type: 'value'
  },
  series: [
    {
      name: 'Email',
      type: 'line',
      data: [120, 132, 101, 134, 90, 230, 210],
      showSymbol: false,
      triggerLineEvent: true,
    },
    {
      name: 'Search Engine',
      type: 'line',
      data: [820, 932, 901, 934, 1290, 1330, 1320],
      showSymbol: false,
      triggerLineEvent: true
    }
  ]
};

myChart.on('mouseover', function(params) {
  if(params.componentSubType == "line"){
    tooltipDisplay = params.seriesName
  }
});

myChart.on('mouseout', function(params) {
  tooltipDisplay = ''
});

myChart .setOption(option)
Run Code Online (Sandbox Code Playgroud)
<html>
  <body>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/echarts/5.3.2/echarts.min.js"></script>
    <div id="main" style="width: 450px; height:170px;"></div>
  </body>
</html>
Run Code Online (Sandbox Code Playgroud)