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...

相关推荐
Hexene...16 小时前
【前端Vue】如何实现echarts图表根据父元素宽度自适应大小
前端·vue.js·echarts
晓得迷路了2 天前
栗子前端技术周刊第 88 期 - Apache ECharts 6.0 beta、Deno 2.4、Astro 5.11...
前端·javascript·echarts
徊忆羽菲3 天前
Echarts3D柱状图-圆柱体-文字在柱体上垂直显示的实现方法
javascript·ecmascript·echarts
DataGear5 天前
如何在DataGear 5.4.1 中快速制作SQL服务端分页的数据表格看板
javascript·数据库·sql·信息可视化·数据分析·echarts·数据可视化
Endeavour_T5 天前
ECharts图表怎么做自适应?
前端·echarts
Kier15 天前
🔋 Vue + ECharts 实现分段折线图教学实战:电池趋势图案例
前端·javascript·echarts
@十八子德月生17 天前
第十章——8天Python从入门到精通【itheima】-99~101-Python基础综合案例-数据可视化(案例介绍=JSON格式+pyecharts简介)
大数据·python·信息可视化·pycharm·echarts·数据可视化
天上掉下来个程小白17 天前
Apache ECharts-02.入门案例
前端·spring boot·apache·echarts·苍穹外卖
GIS好难学19 天前
Echarts数据可视化开发教程+120套开源数据可视化大屏H5模板
前端·信息可视化·echarts
小浪努力学前端20 天前
React + ECharts:给tooltip里的按钮绑定事件,我踩过的那些坑
前端·react.js·echarts