ECharts复杂业务:与tooltip的交互

总是遇到一些神奇的需求,ECharts文档的属性真的有点不好找,靠ChatGPT帮助+反复尝试摸索完成的一些内容,在此记录一下。

背景

期望用ECharts实现------鼠标可以进入图表的tooltip框,并点击其中的内容进行交互

问题1:tooltip会跟随光标移动,光标永远在tooltip框外

设置enterable属性,使鼠标可以进入tooltip

yaml 复制代码
tooltip: {
  enterable: true
}

问题2:图表数据点超多,点与点之间很紧密,即使设置了可以进入tooltip,但移动鼠标后,还没进入,tooltip就飘到下一个点上了,永远追不到

将tooltip紧贴鼠标,使鼠标能够轻松进入框内

js 复制代码
tooltip: {
    position: function (point, params, dom, rect, size) {
      // 提示框位置
      let x, y
      // 当前鼠标位置
      const pointX = point[0]
      const pointY = point[1]
      // 提示框尺寸
      const boxWidth = size.contentSize[0]
      const boxHeight = size.contentSize[1]
      // 容器尺寸
      const viewWidth = size.viewSize[0]
      // const viewHeight = size.viewSize[1]
      // 设置光标左右位置
      if (viewWidth - boxWidth < pointX) {
        // 光标位置 大于 容器减去提示框的位置,右边放不下,放在左侧
        x = pointX - boxWidth
      } else {
        // 默认紧贴光标右侧显示
        x = pointX
      }
      // 设置光标上下位置
      if (boxHeight < pointY) {
        // 光标位置 小于 提示框位置,上面放不下,放在下侧
        y = pointY - boxHeight
      } else {
        // 默认紧贴光标上侧显示
        y = pointY
      }
      // 记录提示框位置
      // if (window.tooltipSpace?.position) window.tooltipSpace.position = [x, y]
      return [x, y]
    }
}

问题3:tooltip过长,超出容器被截断

confine, appendTo, appendToBody等方法在部分情况下都没有用,这里产生的问题归根结底还是tooltip被置入了chart这个元素下,但是其父级设置了overflow: hidden; 而产生的问题,如果其他方法都不生效,可以改动各元素的overflow来解决

问题4:tooltip的formatter使用模版字面量,如何良好的进行交互?

将需要调用的函数绑定在window上,并在挂载和卸载时分别设置和删除(本例基于react)

js 复制代码
// formatter中的模版字面量
// `<div onclick="window.tooltipSpace.expandList(${dataIndex}, ${index})">More</div>`

// useTooltip.js
// 通用内容提取在该文件中
function useTooltip(list) {
  useEffect(() => {
    if (!window.tooltipSpace) {
      window.tooltipSpace = {}
    }
    for (const key in list) {
      window.tooltipSpace[key] = list[key]
    }
    return () => {
      delete window.tooltipSpace
    }
  }, [])
  // return { ... }
}

// app.js
// 在页面上使用
useTooltip({
  expandList: expandList,
  // data: Array(30).fill({ status: -1 }),
  // lastDataIndex: -1
})
function expandList() {}

问题5:在tooltip上交互后,其上的内容不会自动渲染(点击后没有变化)

调用ECharts的dispatchAction使tooltip先消失再显示,实现自动渲染

js 复制代码
export const updateTooltip = (dataIndex: number, chart) => {
  // 先消失后显示,以此实现数据更新
  chart.dispatchAction({
    type: 'hideTip',
    seriesIndex: 0,
    dataIndex // 第几个节点的tooltip
  })
  chart.dispatchAction({
    type: 'showTip',
    seriesIndex: 0,
    position: window.tooltipSpace?.position,
    dataIndex
  })
}

动图DEMO:github.com/Powderbluee...

相关推荐
Book_熬夜!18 小时前
Python基础(六)——PyEcharts数据可视化初级版
开发语言·python·信息可视化·echarts·数据可视化
范特西是只猫2 天前
echarts 自定义标注样式&自定义tooltip弹窗样式
前端·javascript·echarts
范特西是只猫2 天前
echarts map地图动态下钻,自定义标注,自定义tooltip弹窗【完整demo版本】
前端·javascript·echarts
人工智能的苟富贵3 天前
微信小程序中实现类似于 ECharts 的图表渲染及优化
微信小程序·小程序·echarts
GHUIJS3 天前
【Echarts】vue3打开echarts的正确方式
前端·vue.js·echarts·数据可视化
Peanuts.4 天前
VUE使用echarts编写甘特图(组件)
开发语言·javascript·echarts
GHUIJS6 天前
【Echarts】使用多横坐标轴展示近十五天天气预报
javascript·echarts
暖锋丫7 天前
echarts实现湖南省地图并且定时轮询
前端·javascript·echarts
时光匆匆岁月荏苒,转眼我们已不是当年7 天前
【前端echarts】echarts双饼图与easyui列表联动
前端·echarts·easyui
SnowMan19938 天前
高级 ECharts 技巧:自定义图表主题与样式
信息可视化·数据分析·echarts