当前位置:   article > 正文

Echarts提示框(tooltip)位置设置_echarts tooltip位置悬浮窗位置

echarts tooltip位置悬浮窗位置

Echarts提示框(tooltip)浮层位置,不设置时,默认位置会跟随鼠标的位置。

但是,当提示框位置超出图表所在区域时,就可能出现提示框显示不全的问题,如下所示:

         

这就需要我们去设置提示框位置

1、设置提示框位置的方法

方法一:通过数组设置提示框位置

数组第一个元素设置距离父元素左边的距离,数组第二个元素设置距离父元素上边的距离

这种方法设置的提示框位置固定不变,不会随鼠标移动而位置变化

(1)数字设置绝对位置 position: [20, 20]

  1. tooltip: {
  2. trigger: 'axis',
  3. position: [20, 20]
  4. // 等价于
  5. // position: ['20px', '20px']
  6. },

(2)百分比设置相对位置 position: ['50%', '50%']

  1. tooltip: {
  2. trigger: 'axis',
  3. // 相对位置
  4. position: ['50%', '30%']
  5. },

方法二、直接设置position的值为:'inside'|'top'|'bottom'|'left'|'right'

这种方法只在设置   trigger: 'item',   的时候才有效

  • 'inside'  鼠标所在图形的内部中心位置

  • 'top'  鼠标所在图形上侧

  • 'left'  鼠标所在图形左侧

  • 'right'  鼠标所在图形右侧

  • 'bottom'  鼠标所在图形底侧

  1. tooltip: {
  2. trigger: 'item',
  3. position: 'top'
  4. },

方法三、通过回调函数设置提示框位置

回调函数中有:

五个参数

point:鼠标位置,是一个数组,如 [20, 50]

params:Object|Array.<Object>  是需要的数据集

dom:tooltip 的 dom 对象。

rect:一个对象,只有鼠标在图形上时有效,是一个用  x, y, width, height   四个属性表达的图形包围盒。

size:一个对象,包括 dom 的尺寸和 echarts 容器的当前尺寸,例如:{contentSize: [width, height], viewSize: [width, height]}

size中有两个属性:viewSize为外层div的大小,contentSize为tooltip提示框的大小

一个返回值:
(1)返回值可以是一个表示 tooltip 位置的数组,数组值可以是绝对像素值,也可以是相对百分比。

  1. tooltip: {
  2. trigger: 'axis',
  3. position: function (point, params, dom, rect, size) {
  4. return ['40%', 30];
  5. }
  6. },

(2)返回值也可以是一个对象

对象的属性有:top、bottom、left、right

  1. position: function (point, params, dom, rect, size) {
  2. return {left: '40%', bottom: 20};
  3. }

2、设置提示框位置随鼠标移动,并解决提示框显示不全的问题

  1. position: function (point, params, dom, rect, size) {
  2. // 鼠标坐标和提示框位置的参考坐标系是:以外层div的左上角那一点为原点,x轴向右,y轴向下
  3. // 提示框位置
  4. var x = 0; // x坐标位置
  5. var y = 0; // y坐标位置
  6. // 当前鼠标位置
  7. var pointX = point[0];
  8. var pointY = point[1];
  9. // 外层div大小
  10. // var viewWidth = size.viewSize[0];
  11. // var viewHeight = size.viewSize[1];
  12. // 提示框大小
  13. var boxWidth = size.contentSize[0];
  14. var boxHeight = size.contentSize[1];
  15. // boxWidth > pointX 说明鼠标左边放不下提示框
  16. if (boxWidth > pointX) {
  17. x = 5;
  18. } else { // 左边放的下
  19. x = pointX - boxWidth;
  20. }
  21. // boxHeight > pointY 说明鼠标上边放不下提示框
  22. if (boxHeight > pointY) {
  23. y = 5;
  24. } else { // 上边放得下
  25. y = pointY - boxHeight;
  26. }
  27. return [x, y];
  28. }

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Monodyee/article/detail/308744
推荐阅读
相关标签
  

闽ICP备14008679号