Echarts 自定义y轴value值

news2024/11/15 17:41:23

在CSDN问答区,碰到一个有意思的问题,解决思路在这里记录一下。

需求为:进行四等份展示,即中间价差值 = (最大值 - 最小值) / 4,左侧数据从上到下分别为:最大值、最大值 - (最大值 - 最小值) / 4、最大值 - (最大值 - 最小值) / 2、最小值 + (最大值 - 最小值) / 4、最小值

例如有一组数据[260, 132, 232, 123, 69, 33, 134],默认显示是如下效果。

Echarts y轴的value值,会根据series的值来自动计算得出,此时设置yAxis.data.value是无效的。
在这里插入图片描述

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    #chart {
      width: 800px;
      height: 600px;
      margin: 40px auto;
    }
  </style>
</head>

<body>
  <div id="chart"></div>
  <script src="https://cdn.bootcdn.net/ajax/libs/echarts/5.4.2/echarts.min.js"></script>
  <script>
    const data = [260, 132, 232, 123, 69, 33, 134]

    const chart = echarts.init(document.getElementById('chart'))
    chart.setOption({
      xAxis: {
        type: 'category',
        data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
      },
      yAxis: {
        type: 'value',
      },
      series: [
        {
          data: data,
          type: 'line'
        }
      ]
    })
  </script>
</body>
</html>

无法设置data的value值,想来想去只能通过axisLabel的formatter 来做手脚了~

先写个方法把 y 轴值计算出来

// 通过规则计算得出 y 轴值
function computedNum(maxNum, minNum) {
  const num1 = Math.round(minNum + (maxNum - minNum) / 4)
  const num2 = Math.round(maxNum - (maxNum - minNum) / 2)
  const num3 = Math.round(maxNum - (maxNum - minNum) / 4)

  return [minNum, num1, num2, num3, maxNum]
}

const maxNum = Math.max(...data)
const minNum = Math.min(...data)
const numArr = computedNum(maxNum, minNum)

通过 formatter 强制渲染计算出的值

yAxis: {
  type: 'value',
  max: maxNum,
  min: minNum,
  splitNumber: 4,
  axisLabel: {
    formatter: (val, index) => {
      // 通过这里强制返现自己计算出的数值
      return numArr[index]
    }
  }
}

在这里插入图片描述
就变成上图这个样子,好像不太对劲,splitNumber不好使啊,官方是这么说明的
在这里插入图片描述

如何显示指定段数呢,这里固定了最大、最小值,计算出x段的分割间隔,是不是就能按照自定义段数显示了?

// 计算间隔值
function getInterval(arr, splitNumber) {
  // 排序 sort会改变原数组,这里slice浅拷贝一下
  const tempArr = arr.slice().sort((a, b) => a - b)
  // 最大和最小值的距离
  const distance = tempArr[tempArr.length - 1] - tempArr[0]
  // 计算等分间隔值
  const interval = distance / splitNumber
  return interval
}
const interval = getInterval(data, 4)

// yAxis 配置改为如下
yAxis: {
  type: 'value',
  max: maxNum,
  min: minNum,
  interval: interval,
  axisLabel: {
    formatter: (val, index) => {
      // 通过这里强制返现自己计算出的数值
      return numArr[index]
    }
  }
}

最终实现了需求要的效果
在这里插入图片描述

完整代码

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    #chart {
      width: 800px;
      height: 600px;
      margin: 40px auto;
    }
  </style>
</head>

<body>
  <div id="chart"></div>
  <script src="https://cdn.bootcdn.net/ajax/libs/echarts/5.4.2/echarts.min.js"></script>
  <script>
    const data = [260, 132, 232, 123, 69, 33, 134]

    // 通过规则计算得出 y 轴值
    function computedNum(maxNum, minNum) {
      const num1 = Math.round(minNum + (maxNum - minNum) / 4)
      const num2 = Math.round(maxNum - (maxNum - minNum) / 2)
      const num3 = Math.round(maxNum - (maxNum - minNum) / 4)

      return [minNum, num1, num2, num3, maxNum]
    }

    const maxNum = Math.max(...data)
    const minNum = Math.min(...data)
    const numArr = computedNum(maxNum, minNum)
    // 计算间隔值
    function getInterval(arr, splitNumber) {
      // 排序  sort会改变原数组,这里slice浅拷贝一下
      const tempArr = arr.slice().sort((a, b) => a - b)
      // 最大和最小值的距离
      const distance = tempArr[tempArr.length - 1] - tempArr[0]
      // 计算等分间隔值
      const interval = distance / splitNumber
      return interval
    }
    const interval = getInterval(data, 4)

    const chart = echarts.init(document.getElementById('chart'))
    chart.setOption({
      xAxis: {
        type: 'category',
        data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
      },
      yAxis: {
        type: 'value',
        max: maxNum,
        min: minNum,
        interval: interval,
        axisLabel: {
          formatter: (val, index) => {
            // 通过这里强制返现自己计算出的数值
            return numArr[index]
          }
        }
      },
      series: [
        {
          data: data,
          type: 'line'
        }
      ]
    })
  </script>
</body>
</html>

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

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

相关文章

测试工程师用了3个月从月薪8k涨到12k,我是这么做到的?

先说一下自己的个人情况&#xff0c;大专生&#xff0c;18年通过校招进入湖南金蝶软件公司&#xff0c;干了接近3年的测试工程师&#xff0c;今年年初&#xff0c;感觉自己不能够在这样下去了&#xff0c;长时间呆在一个舒适的环境会让一个人堕落&#xff01; 而我已经在一个企…

MySQL知识学习04(MySQL事务隔离级别详解)

1、事务隔离级别总结&#xff1f; SQL 标准定义了四个隔离级别&#xff1a; READ-UNCOMMITTED(读取未提交) &#xff1a; 最低的隔离级别&#xff0c;允许读取尚未提交的数据变更&#xff0c;可能会导致脏读、幻读或不可重复读。READ-COMMITTED(读取已提交) &#xff1a; 允许…

剧本杀游戏app开发

剧本杀游戏app开发通常会涉及以下技术&#xff1a; 开发语言&#xff1a;剧本杀游戏app可以使用各种编程语言进行开发&#xff0c;例如Java、Kotlin、Swift等。 游戏引擎开发&#xff1a;为了实现游戏过程中的角色扮演、对话、动画等效果&#xff0c;需要使用适当的游戏…

Docker-Compose介绍

文章目录 一、Docker-compose 简介二、YAML 文件格式及编写注意事项三、Docker Compose配置常用字段四、Docker Compose 常用命令五、Docker Compose 文件结构六、compose 部署1、Docker Compose 环境安装2、compose部署nginx3、compose部署lnmp 一、Docker-compose 简介 Dock…

odoo 常用小部件及其用法

文章目录 1) 显示百分比2) 标签组件3) handle组件&#xff08;拖拽排序&#xff09;4) 状态栏组件5) binary组件6) 货币组件7) tatinfo组件8) 日期型字段只显示年月 odoo的一些小部件主要定义在&#xff1a;模块/static/src/js下 1) 显示百分比 模型字段execution_percent定义…

api接口如何有效对接

一、背景 在平时工作中&#xff0c;经常会遇到的一种场景是&#xff1a;A公司要对接B公司的API方法&#xff0c;这时&#xff0c;A公司就要阅读B公司的接口文档&#xff0c;从接口文档中找到自己需要对接的API&#xff0c;并根据接口文档的要求&#xff0c;完成编码工作&#…

为什么要建数据仓库,而不是直连数据源?

各位数据的朋友&#xff0c;大家好&#xff0c;我是老周道数据&#xff0c;和你一起&#xff0c;用常人思维数据分析&#xff0c;通过数据讲故事。 今天和大家聊一个话题&#xff1a;为什么BI软件要用构建数据仓库&#xff0c;而不是直连数据源的方式开发报表&#xff1f;&…

docker的底层原理,带你上天

1、docker的层级怎么看 先查看当前机器上有哪些镜像 docker images 这里选看mysql的层级 docker image inspect mysql:5.7.29 命令。其中RootFS部分则是表示了分层信息。 2、查看docker的系统信息 因为这台机器的docker不是我安装的&#xff0c;所以不知道具体的根目录在哪里…

redis之benchmark工具:benchmark是redis自带的性能测试工具

从本篇文章开始&#xff0c;博主将开始对redis的探索&#xff0c;今天的咱们先来聊聊benchmark性能测试工具&#xff0c;通过此工具来检查以下redis的读写能能力以及环境问题。通过此工具可以让我们更清楚的认识到redis具有怎样的能力&#xff0c;是否要进行其他的配置例如&…

【css】CSS层叠样式表二

目录 一、Emmet语法 1、快速生成HTML结构语法 2、快速生成CSS样式语法 3、vscode自动格式化代码 二、CSS的复合选择器 1、什么是复合选择器 1.1后代选择器&#xff08;重要&#xff09; 1.2子选择器&#xff08;重要&#xff09; 1.3并集选择器&#xff08;重要&…

Downie 4 4.6.16 MAC上最新最好用的一款视频下载工具

Downie for Mac 简介 Downie是Mac下一个简单的下载管理器&#xff0c;可以让您快速将不同的视频网站上的视频下载并保存到电脑磁盘里然后使用您的默认媒体播放器观看它们。 Downie 4 下载 Downie 4 for Mac Downie 4 for Mac软件特点 支持许多站点 -当前支持1000多个不同的…

SLAM中将地图映射到谷歌地图上的方法——完美运行

文章目录 前言一、rviz_satellite二、mapviz 前言 老是看到论文中有将地图映射到谷歌地图上的图&#xff0c;实在是泰裤辣&#xff01;&#xff01;&#xff08;武汉大学&#xff09; 搜索了很久&#xff0c;发现有两种可视化软件&#xff0c;分别为rviz_satellite和mapviz。…

换脸ai的方法分享!这几个换脸APP巨好用。​

换脸ai的方法分享&#xff01;换脸AI是一种基于人工智能技术的图像处理应用&#xff0c;它可以将一个人的面部特征和表情应用到另一张照片或视频中&#xff0c;实现快速、高效的人脸替换。这种技术利用机器学习模型分析和学习大量的人脸数据&#xff0c;训练出一种“生成对抗网…

GPU基础与CUDA编程入门

文章目录 一、GPU和CPU的区别GPU&#xff1a; 高吞吐量导向设计CPU&#xff1a; 低延迟导向设计GPU适合什么场景:什么是Prefetch&#xff1f; 二、CUDA与OpenCL三、CUDA编程并行计算整体流程内存模型线程块网格Grid&#xff1a;并行线程块组合线程束SIMD 四、CUDA编程实例&…

ModuleNotFoundError: No module named ‘allennlp‘解决方法

1. 准备工作 由于本人复现论文要安装allennlp的包但是遇到些问题&#xff0c;所以特地记录一下 需求:在SBN环境下安装allennlp的包 1.创建环境 创建一个环境名为SBN的环境名字 python版本为3.8.5 可以根据自己需求指定&#xff0c; conda create -n SBN python3.8.5conda a…

企业微信-构造网页授权链接实现登录

文档地址&#xff1a;构造网页授权链接 - 接口文档 - 企业微信开发者中心 注意&#xff1a; 1.redirect_uri&#xff1a;回调链接地址&#xff0c;需要使用urlencode对链接进行处理 2.scope&#xff1a;如果需要获取成员的头像、手机号等信息需要设为snsapi_privateinfo 例如前…

ChatGPT4.0火爆全球,是什么让它独领风骚?

ChatGPT造就了互联网历史上又一个神话&#xff0c;仅用两个月时间就成功吸引了1亿用户&#xff0c;成为全球互联网应用中增长速度最快的一个。连比尔盖茨都称&#xff1a;ChatGPT的历史意义重大&#xff0c;不亚于PC或互联网诞生。这个热度以至于ChatGPT官网长期都处于满负荷运…

射频功率放大器在S180肿瘤细胞膜研究中的应用

实验名称&#xff1a;聚焦超声对S180肿瘤细胞膜理化性质的影响 研究方向&#xff1a;生物医疗 测试目的&#xff1a; 细胞膜是细胞生命活动中有着复杂功能的重要结构其基本作用在于维持细胞内外环境的相对稳定而其通透性、完整性及流动性等理化性质则与胞内外信息传递、物质…

Unity——Mirror学习(01)

1.下载 Mirror是一个简单高效的开源的unity多人游戏网络框架&#xff0c;Mirror在Unity商店中是免费的&#xff0c;因此直接加入自己的资源库并在导入即可。 官方API地址&#xff1a;https://mirror-networking.gitbook.io/docs 2.使用 1.创建场景的网络管理器 网络管理器…

C#,生信软件实践(03)——DNA数据库GenBank格式详解及转为FASTA序列格式的源代码

1 GenBank 1.1 NCBI——美国国家生物技术信息中心&#xff08;美国国立生物技术信息中心&#xff09; NCBI&#xff08;美国国立生物技术信息中心&#xff09;是在NIH的国立医学图书馆&#xff08;NLM&#xff09;的一个分支。它的使命包括四项任务&#xff1a;1. 建立关于分…