echarts 柱状体点击空白处

news2025/1/18 19:09:08

在这里插入图片描述
点击红框里的空白区域:

再data里定义的idlist变量:
 idList: [
        800, 300, 500, 400, 800, 300, 500, 400, 800, 300, 500, 400, 800, 300,
        500, 400, 800, 300, 500, 400,
      ]

//以下是js代码

     var chartDom = document.getElementById('echartsOne')
      this.myChart = echarts.init(chartDom)

      this.option = {
        // 提示牌
        tooltip: {
          confine: true, //是否将 tooltip 框限制在图表的区域内。
          trigger: 'axis',
          extraCssText: 'z-index:3',
          axisPointer: {
            type: 'line',
            label: {
              backgroundColor: '#283b56'
            }
          }
        },
        xAxis: [
          {
            type: 'category',
            boundaryGap: true,
            data:[
        "农、林、牧、渔业",
        "采矿业",
        "制造业",
        "电力、热力、燃气及水生产和供应业",
        "建筑业",
        "批发和零售业",
        "交通运输、仓储和邮政业",
        "住宿和餐饮业",
        "信息传输、软件和信息技术服务业",
        "金融业",
        "房地产业",
        "租赁和商务服务业",
        "科学研究和技术服务业",
        "水利、环境和公共设施管理业",
        "居民服务、修理和其他服务业",
        "教育",
        "卫生和社会工作",
        "文化、体育和娱乐业",
      ],
            // 设置x轴字体颜色和大小
            axisLabel: {
              textStyle: {
                color: 'rgba(51,51,51, 0.75)',
                fontSize: 12
              },
              interval: 0, //代表显示所有x轴标签显示

              formatter: function(params) {
                var newParamsName = '' // 最终拼接成的字符串
                var paramsNameNumber = params.length // 实际标签的个数
                var provideNumber = 2 // 每行能显示的字的个数
                var rowNumber = Math.ceil(paramsNameNumber / provideNumber) // 换行的话,需要显示几行,向上取整
                /**
                 * 判断标签的个数是否大于规定的个数, 如果大于,则进行换行处理 如果不大于,即等于或小于,就返回原标签
                 */
                // 条件等同于rowNumber>1
                if (paramsNameNumber > provideNumber) {
                  /** 循环每一行,p表示行 */
                  for (var p = 0; p < rowNumber; p++) {
                    var tempStr = '' // 表示每一次截取的字符串
                    var start = p * provideNumber // 开始截取的位置
                    var end = start + provideNumber // 结束截取的位置
                    // 此处特殊处理最后一行的索引值
                    if (p == rowNumber - 1) {
                      // 最后一次不换行
                      tempStr = params.substring(start, paramsNameNumber)
                    } else {
                      // 每一次拼接字符串并换行
                      tempStr = params.substring(start, end) + '\n'
                    }
                    newParamsName += tempStr // 最终拼成的字符串
                  }
                } else {
                  // 将旧标签的值赋给新标签
                  newParamsName = params
                }
                //将最终的字符串返回
                return newParamsName
              }
            },
            axisTick: {
              //x轴刻度线
              show: false
            },
            axisLine: {
              lineStyle: {
                color: 'rgba(51,51,51, 0.75)', //左边线的颜色
                width: '1' //坐标线的宽度
              }
            }
          }
        ],
        yAxis: [
          {
            type: 'value',
            scale: true,
            name: '单位: 家',
            // 设置y轴顶部文字样式
            nameTextStyle: {
              color: 'rgba(51,51,51, 0.75)',
              fontSize: 12
            },
            max: function(value) {
              return Math.ceil(value.max)
            },
            min: 0,
            boundaryGap: [0.2, 0.2],
            // 设置y轴字体颜色和大小
            axisLabel: {
              textStyle: {
                color: 'rgba(51,51,51, 0.75)',
                fontSize: 12
              }
            },
            axisTick: {
              //x轴刻度线
              show: false
            },
            axisLine: {
              //y轴坐标轴,false为隐藏,true为显示
              show: false,
              lineStyle: {
                color: '#1b3b30' //左边线的颜色
                // width: "2", //坐标线的宽度
              }
            },
            // y轴分割线的设置
            splitLine: {
              show: false,
              lineStyle: {
                color: '#1b3b30' //左边线的颜色
                // width: "2", //坐标线的宽度
              }
            }
          }
        ],
        // 改变图表的位置
        grid: {
          top: '15%',
          left: '8%',
          right: '2%',
          bottom: '45%'
        },

        series: [
          // 柱状图
          {
            name:  '统计数量(家)',
            type: 'bar',
            barWidth: 20, //柱图宽度
            itemStyle: {
              normal: {
                barBorderRadius: [0, 0, 0, 0],
                borderColor: 'rgba(0, 255, 181, 0.87)',
                borderWidth: 2,
                // 拐点渐变色
                color: {
                  type: 'linear',
                  x: 0,
                  y: 0,
                  x2: 0,
                  y2: 1,
                  colorStops: [
                    {
                      offset: 0,
                      color: 'rgba(0, 255, 181, 1)' // 0% 处的颜色
                    },
                    {
                      offset: 0.5,
                      color: 'rgba(0, 255, 181, 0.5)' // 0% 处的颜色
                    },
                    {
                      offset: 1,
                      color: 'rgba(0, 255, 181, 0)' // 100% 处的颜色
                    }
                  ],
                  global: false // 缺省为 false
                }
              }
            },
            data:  [
        800, 300, 500, 400, 800, 300, 500, 400, 800, 300, 500, 400, 800, 300,
        500, 400, 800, 300, 500, 400,
      ]
          }
        ]
      }

      this.option && this.myChart.setOption(this.option)
      // 屏幕适配
      window.addEventListener('resize', () => {
        this.myChart.resize()
      })
      //主要的点击代码在这-----------------------------------------------
      this.myChart.getZr().on('click', param => {
        //获取自定义变量barIds的值,barIds要和option的series里自定义的一样
        const pointInPixel = [param.offsetX, param.offsetY]
        if (this.myChart.containPixel('grid', pointInPixel)) {
          const xIndex = this.myChart.convertFromPixel({ seriesIndex: 0 }, [param.offsetX, param.offsetY])[0]
          // console.log(xIndex, 'x轴')
          this.myChart.resize()
          this.firmid = this.idList[xIndex]
          // console.log(xIndex, this.firmid, 'x轴')
          this.getList()
          this.visible = true
        }
      })

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/719410.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

数据产品经理的职业发展机会

在当今的数字时代&#xff0c;数据产品经理已成为许多企业中不可或缺的角色。随着越来越多的企业开始将数据应用于业务决策和产品开发中&#xff0c;数据产品经理的需求也不断增加。因此&#xff0c;学习成为一名数据产品经理成为了许多人的热门选择。下面说一说关于如何学习数…

tty(imx serial)(二)

基于linux-3.14.16 基于imx分析 一、串口设备注册 注册了一个uart设备驱动&#xff0c;和一个平台设备驱动 先一个一个看 1、serial_imx_driver平台设备驱动 看看匹配的设备树&#xff0c;imx6qdl.dtsi定义了很多&#xff0c;我们只看一个 如上图&#xff0c;设备树描述了…

基于 RK3399+fpga 的 VME 总线控制器设计(二)硬件和FPGA逻辑设计

3.2 FPGA 最小系统设计 FPGA 最小系统是指可以使 FPGA 正常工作的最基本的系统&#xff0c;主要包括电源电 路、配置电路、时钟和复位电路。本次设计使用的 FPGA 为紫光同创的 PG2L100H, 接下来具体介绍 FPGA 最小系统各个部分的电路设计。 &#xff08; 1 &#…

RflySim平台——高可信度的无人控制系统开发、测试与评估平台

01/RflySim平台背景 智能无人系统是一个复杂系统&#xff0c;涉及机械、控制、计算机、通信和材料等多个领域技术&#xff0c;而AI无疑是开发IUS所需的关键技术之一。随着新一代人工智能兴起&#xff0c;我们正面临一场新的工业革命&#xff0c;人类创造了各种无人系统&#x…

论文解读|点云分割中用于多尺度处理的金字塔结构

原创 | 文 BFT机器人 01 论文内容 这篇论文是关于点云分割中金字塔架构的多尺度处理的详细解读。 点云数据的语义分割是自动驾驶和其他应用中的关键任务。在这项工作中&#xff0c;作者指出了在点云分割中移动U形结构的紧迫需求和巨大好处&#xff0c;并受到图像分割领域最新进…

Fleet Farm EDI 需求详解

Fleet Farm 是一家成立于1955年的美国卖场&#xff0c;总部位于威斯康星州。作为一个全方位的零售商&#xff0c;Fleet Farm 提供了广泛的商品和服务&#xff0c;涵盖了农业用品、家居装饰、户外用品、汽车用品、园艺用品等多个领域。他们的使命是为客户提供高品质的产品和卓越…

《阿里大数据之路》读书笔记:第二章 日志采集

第二章 日志采集 一、浏览器的页面日志采集 浏览器的页面型产品/服务的日志采集可分为两大类&#xff1a; 页面浏览&#xff08;展现&#xff09;日志采集 指一个页面被浏览器加载呈现时采集的日志 此类日志是最基础的互联网日志 此类日志是目前所有互联网产品的两大基本指…

【Linux】LVS负载均衡群集 NAT模式

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 LVS负载均衡群集 NAT模式 一、理解负载均衡群集的原理1.企业群集应用概述2.企业群集分类3.负载均衡群集架构4.负载均衡群集工作模式分析5.NAT模式6.TUN模式7.DR模式 二、LVS虚…

ESP32 BLE蓝牙服务端客户端通信

官方帮助见这里 BLE服务端命令 ATRESTORE//复位 ATBLEINIT2 //将esp32设置成蓝牙SERVER ATBLEGATTSSRVCRE //GATTS创建服务, 建议初始化后就建立GATTS, 建立连接在创建会报错 ATBLEGATTSSRVSTART //GATTS 开启全部服务。 ATBLEGATTSCHAR? //GATTS 发现服务特征 ATBLEADDR…

回收站的文件删除了怎么恢复?实用的2个方法推荐!

我一直以为回收站里的文件都是我自己删除的文件&#xff0c;因此没有怎么在意。但是我刚刚清空了回收站&#xff0c;却发现我有些重要的文件是被误删而放入回收站的&#xff0c;现在这些文件都被删除了&#xff0c;这可怎么办&#xff1f; 回收站中通常会存放很多我们删除的文件…

使用QT: ActiveX控件生成文件,实现在QT项目中调用.c文件

以连接的其他控件为例&#xff0c;控件的位数&#xff08;32/64&#xff09;&#xff0c;需要和QT编译器保持一致 我在此处连接的是.h和.c文件的类接口&#xff0c;在QT中使用 原始接口&#xff1a; 1.在QT程序中添加模块 QT axcontainer2.查看COM控件的UUID 打开一个.ui文件…

Java基础-多线程JUC-生产者和消费者

1. 生产者与消费者 实现线程轮流交替执行的结果&#xff1b; 实现线程休眠和唤醒均要使用到锁对象&#xff1b; 修改标注位&#xff08;foodFlag&#xff09;&#xff1b; 代码实现&#xff1a; public class demo11 {public static void main(String[] args) {/*** 需求&#…

java jvm TLAB是什么?指针碰撞解释,空闲列表解释

1. 对象的创建&#xff1a; 当Java虚拟机遇到一条字节码new指令时&#xff0c;首先将去检查这个指令的参数是否能在常量池中定位到 一个类的符号引用&#xff0c;并且检查这个符号引用代表的类是否已被加载、解析和初始化过。如果没有&#xff0c;那必须先执行相应的类加载过程…

SpringBoot 实现审核功能

一、审核功能实现的方式 1、普通 方案&#xff1a;经办时入A表&#xff0c;审核后从A表读取数据&#xff0c;然后操作目标B表&#xff1b; 优势&#xff1a;思路简单 劣势&#xff1a;对后端功能实行高度的嵌入&#xff1b;审核功能数据操作不统一 2、弹框式 方案&#x…

HummerRisk 配置 HTTPS访问

简介 HummerRisk 是开源的云原生安全平台&#xff0c;以非侵入的方式解决云原生的安全和治理问题。核心能力包括混合云的安全治理和云原生安全检测。 HTTPS&#xff08;Hypertext Transfer Protocol Secure&#xff09;是一种通过加密和身份验证来保护网络通信安全的协议。它…

ChatGPT对高等教育的可能影响与对策建议

ChatGPT来袭&#xff0c;将对高等教育带来哪些影响&#xff0c;我们又该如何应对&#xff1f; 对于ChatGPT&#xff0c;有人欢喜有人忧&#xff0c;不同人、不同领域评价不一。在一些人眼里&#xff0c;它就是天使&#xff0c;而在另外一些人眼里&#xff0c;它几乎可以说是魔…

php导出pdf

插件官网&#xff1a;TCPDF 博主用的是tp6框架 、tcpdf插件 composer require tecnickcom/tcpdf --ignore-platform-reqs 后面是忽略平台要求的参数 ---------------中文乱码start------------------ 关于中文乱码问题&#xff1a; 网上说的下载字体放入fonts 利用tools…

Linux之系统管理

系统管理 Linux中的进程和服务 计算机中&#xff0c;一个正在执行的程序或命令&#xff0c;被叫做“进程”&#xff08;process&#xff09;。 启动之后一直存在、常驻内存的进程&#xff0c;一般被称作“服务”&#xff08;service&#xff09; service 服务管理&#xff…

GaussDB OLTP云数据库配套工具DDM

目录 一、前言 二、DDM定义 三、DDM业务架构 四、为什么需要DDM? 五、DDM特性 六、DDM应用场景 一、前言 现在越来越多的企业应用在逐步向云平台迁移&#xff0c;同时这对云平台带了一个严峻的考验和挑战。但针对华为云GaussDB数据库&#xff0c; 我们在生态方面做了比…