ECharts柱形图数据差距过大触发点击事件

目录

前言

一、普通点击事件

二、使用getZr()点击


前言

在项目开发中,由于一些数据量差距过大,导致偏小的值的点击事件难以触发,此时我们可以不用传统的点击事件,而是用可以包括背景区域的点击事件来触发。相当于点击整个坐标轴区域都能触发点击事件而不只是点击已有的数据形成的柱体


一、普通点击事件

在下图中如果想点击柱体触发点击事件就比较困难,因为数据差距过大,导致柱体面积很小,不利于点击

chart.on 点击事件只能接收有数据部分的点击事件, 柱子上方无法响应, 没有数据的柱子无法响应.

TypeScript 复制代码
                 chart.on('click', (params: any) => {
                  });

二、使用getZr()点击

使用到ECharts的api:containPixel、convertFromPixel在下面链接可以查看

ISQQW.COM x ECharts 文档(国内同步镜像) - API

TypeScript 复制代码
  //防止触发多次点击
  chart.getZr().off('click');
  //防止数据差距过大 柱状图数值太小点击不了柱体 getZr()可以点击到整个坐标轴
  chart.getZr().on('click', (params: any) => {
  const pointInPixel = [params.offsetX, params.offsetY];
  //'grid'表示整个直角坐标系网格区域(下图实例红框内容)
  //可以在option配置中grid:{show:true}显示
  //if语句判断给定的点是否在指定的坐标系或者系列上。
    if (chart.containPixel('grid', pointInPixel)) {
              // 获得点击的x,y坐标
             let position = chart.convertFromPixel({ seriesIndex: 0 }, [
                            params.offsetX,
                            params.offsetY,
                        ]);
                        // x轴数据的索引值
                        let xIndex = position[0];
                      
                       
  }
                });

此时整个坐标轴都可以点到,拿到xIndex就拿到了柱状图对应的索引值,此时就可以进行后续操作。

相关推荐
ai超级个体20 分钟前
别再吹牛了,100% Vibe Coding 存在无法自洽的逻辑漏洞!
前端·ai·ai编程·vibe coding
Mike_jia43 分钟前
🎓 OpenMAIC 终极指南:清华开源的多智能体 AI 互动课堂平台
前端
踩着两条虫1 小时前
告别低代码“黑盒”!VTJ.PRO 2.0:用AI与自由重塑Vue3开发
前端·低代码·ai编程
OpenTiny社区1 小时前
WebAgent :基于 MCP 协议打造的智能应用“超级路由器”
前端·agent·mcp
吴声子夜歌1 小时前
TypeScript——模块解析
javascript·ubuntu·typescript
dweizhao1 小时前
别再用 Figma 画线框图了,Google 这款免费工具直接出 UI 稿
前端
han_2 小时前
JavaScript设计模式(五):装饰者模式实现与应用
前端·javascript·设计模式
ProgramHelpOa2 小时前
Amazon SDE Intern OA 2026 最新复盘|70分钟两题 Medium-Hard
java·前端·javascript
smchaopiao2 小时前
如何用CSS和JS搞定全屏图片展示
前端·javascript·css
酉鬼女又兒2 小时前
零基础快速入门前端CSS Transform 与动画核心知识点及蓝桥杯 Web 应用开发考点解析(可用于备赛蓝桥杯Web应用开发)
开发语言·前端·css·职场和发展·蓝桥杯·html