echartjs实现cross十星辅助线实现示例详解

 更新时间:2022年12月11日 11:01:24   作者:九酒  
这篇文章主要为大家介绍了echartjs实现cross十星辅助线实现示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

前言

项目是金融项目,就像支付宝基金的走势图一样。但图表库使用的是 echart 而不是 antv 的 f2,要问为什么不直接用 f2 ?问就是因为项目历史包袱。

背景

了解过 echart 的都知道,官方提供了十星辅助线,只要设置 axisPointer 的 type 为cross 即可实现类似股票走势图的十星线,纵轴吸附最近的点,横轴跟随鼠标或手势的触点位置,如下图

功能没问题,但是若作为基金产品,老板要求要对标支付宝,要达到如下图的效果

但既然对标阿里,为什么不用 antv ?我也问过。但从风险和成本的角度看,反正最终是老板不让。

既然不能切 antv,上面的 cross 又不能满足老板的要求,那么就要老老实实研究 echart 怎么实现了。

方案的过程就不详细说了,反正最后灵光一现,考虑到可以用 type 为 line 的 axisPointer 和 markline 来达到了老板的需求。

具体实现

1、开启 tooltip,并将 tooltip 的 trigger 设置为 axis。

2、xAxis 中设置 axisPointer,这里设置 snap 为 true,保证纵向辅助线吸附。

3、series 中设置 markline,默认的 markline 会自带起点和箭头,为了做十星,这里需要将起点和箭头通过将 symbol 设置为 none 来取消,默认 markline 的显示会有动画,而十星没有,所以还要将 animation 设置为 false 来禁止 markline 的缓动展示动画

4、完成以上步骤将会得到一个跟随手势的纵线和固定位置的横线(markline),若要达到完美的十星,这里需要配置一个能跟随手势的横线,那么这里需要通过获取纵线吸附后的点来重设 markline 的位置,我这里在 tooltip 的 formatter 中进行处理,因为这里能拿到我要的点(目前没找到其他好的办法,有知道的也可以提供下想法)

5、这样看起来就基本完成了,但是考虑到移动端,手势离开图表坐标系时,axisPointer 会自动消失,但是按照我们的实现,markline 不会跟随消失,这时候我们就需要通过监听点击的位置来再次控制 markline 的展示了

大致的配置如下

// 5 这里设置异步是因为 demo 的代码是部分代码,执行的时候可能myChart 还没渲染完成,真实处理的时候若 chart 已经渲染完成的话无需异步处理
setTimeout(()=>{
  var _componentsViews = myChart._componentsViews;
  var  view = _componentsViews.find(item => item.type === 'grid') || {};
  debugger
  var  rect = view.__model.coordinateSystem._rect;
  var  rectObj = {
    x: rect.x,
    x1: rect.x + rect.width,
    y: rect.y,
    y1: rect.y + rect.height
  };
  // 设置监听
  myChart._zr.on('mouseup', (e) => {
    var { offsetX, offsetY } = e;
    // // 点击图表之外时markline消失
    if (offsetX < rectObj.x || offsetX > rectObj.x1 || offsetY < rectObj.y || offsetY > rectObj.y1) {
      chart.setOption({
        series: [{
          markLine: {
            data: [],
            label: {
              show: false
            }
          }
        }]
      });
    }
  });
}, 1000)
...
option = {
    tooltip: {
        // 1
        trigger: "axis",
        // 4
        formatter(arg) {
          // 这里需要异步处理以下,否则无法设置成功
          setTimeout(function() {
            myChart.setOption({
                series: [{
                  markLine: {
                    data: [{
                      yAxis: arg[0].value[1],
                      label: {
                        show: true
                      }
                    }]
                  }
                }]
            })
          }, 0);
        }
        ...
    },
    xAxis: {
        // 2
        axisPointer: {
          snap: true,
          label: {
            show: true,
            backgroundColor: "#0000ff",
            color: '#fff',
            ...
          },
          lineStyle: {
            color: '#0000ff'
          },
          ...
        },
     },
     yAxis: {
         ...
     },
     series: [
        {
          name: '模拟数据2',
          type: 'line',
          ...
          // 3
          markLine: {
            symbol: 'none',
            silent: true,
            data: [
              {
                yAxis: 0,
                label: {
                  show:false
                }
              }
            ],
            label: {
              show: true,
              position: 'start',
              backgroundColor: '#0000ff',
              color: '#ffffff',
              padding: 2
            },
            lineStyle: {
              color: '#0000ff'
            },
            animation: false
          },
        }
    ]
}

以上,类支付宝的走势图十星就完成了,年度 kpi 达成 (•̀ᴗ• )?

有需要的可以参考已实现的 demo,也不知道官方会保存多久,且看且珍惜。

以上就是echartjs实现cross十星辅助线实现示例详解的详细内容,更多关于echartjs cross十星辅助线的资料请关注脚本之家其它相关文章!

相关文章

  • 快速实现JS图片懒加载(可视区域加载)示例代码

    快速实现JS图片懒加载(可视区域加载)示例代码

    目前很多网站,在图片加载时均采用了一种名为懒加载的方式,具体表现为,当页面被请求时,只加载可视区域的图片,其它部分的图片则不加载,只有这些图片出现在可视区域时才会动态加载这些图片,下面本文就介绍了JS图片懒加载(可视区域加载)的实现方法,一起来看看吧。
    2017-01-01
  • js正则表达式验证邮件地址

    js正则表达式验证邮件地址

    这篇文章主要介绍了js正则表达式验证邮件地址,利用javaScript语言实现一下电子邮件地址验证程序,使用的是JavaScript语言的正则表达式库,感兴趣的小伙伴们可以参考一下
    2015-11-11
  • Bootstrap 网站实例之单页营销网站

    Bootstrap 网站实例之单页营销网站

    这篇文章主要介绍了Bootstrap 网站实例之单页营销网站的相关资料,本文给大家介绍的非常详细具有一定的参考借鉴价值,需要的朋友可以参考下
    2016-10-10
  • JSON 对象未定义错误的解决方法

    JSON 对象未定义错误的解决方法

    下面小编就为大家带来一篇JSON 对象未定义错误的解决方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-09-09
  • ES6知识点整理之模块化的应用详解

    ES6知识点整理之模块化的应用详解

    这篇文章主要介绍了ES6知识点整理之模块化的应用,结合实例形式分析了基于node.js环境下模拟ES6模块化配置与使用相关操作技巧,需要的朋友可以参考下
    2019-04-04
  • uniapp中修改打包路径的实现步骤

    uniapp中修改打包路径的实现步骤

    本文主要介绍了uniapp中修改打包路径,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2025-02-02
  • JavaScript提升机制Hoisting详解

    JavaScript提升机制Hoisting详解

    这篇文章主要介绍了JavaScript提升机制Hoisting详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-10-10
  • JavaScript逆向案例之如何破解登录密码

    JavaScript逆向案例之如何破解登录密码

    这篇文章主要介绍了JavaScript逆向案例之如何破解登录密码,文章通过12306的登陆方法展开用户登录密码的参数破解办法,感兴趣的小伙伴可以参考一下
    2022-06-06
  • JavaScript实现in-place思想的快速排序方法

    JavaScript实现in-place思想的快速排序方法

    这篇文章主要介绍了JavaScript实现in-place思想的快速排序方法的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-08-08
  • 前端Webpack配置之eval-source-map使用方法

    前端Webpack配置之eval-source-map使用方法

    eval-source-map 是 Webpack 中 devtool 选项的一种模式,它提供了一种内联 Source Map 的方式,用于开发环境中的源代码映射,这篇文章主要介绍了前端Webpack配置之eval-source-map使用方法,需要的朋友可以参考下
    2024-12-12

最新评论