【Echarts】详解 柱状图(Mixed Line and Bar)!!快来看看吧!

2023-11-01 01:50

本文主要是介绍【Echarts】详解 柱状图(Mixed Line and Bar)!!快来看看吧!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

柱状图(Mixed Line and Bar)的实现

先看效果

在这里插入图片描述

文件目录

在这里插入图片描述

获取Echarts

在这里插入图片描述

引入Echarts
<!DOCTYPE html>
<html>
<head><meta charset="utf-8"><!-- 引入 ECharts 文件 --><script src="../incubator-echarts-5.0.0-alpha.2/dist/echarts.min.js"></script>
</head>
</html>
绘制图表

在绘图前我们需要为 ECharts 准备一个具备高宽的 DOM 容器

<body style="background: black;"><!-- 为 ECharts 准备一个具备大小(宽高)的 DOM --><div id="main" style="width: 835px; height: 670px"></div>
</body>

然后就可以通过echarts.init方法初始化一个 echarts 实例并通过setOption方法生成一个 柱状图(Mixed Line and Bar)

 <script type="text/javascript">// 基于准备好的dom, 初始化echarts实例var myChart = echarts.init(document.getElementById('main'));// 使用刚指定的配置项和数据显示图表myChart.setOption(option)</script>
代码步骤拆分
指定图标的配置和数据
数据源
  // 数据集
const dataList = [{date: '08/01', value: 116, orderNum: 14},{date: '08/02', value: 256, orderNum: 14},{date: '08/03', value: 446, orderNum: 25},{date: '08/04', value: 111, orderNum: 18},{date: '08/05', value: 416, orderNum: 47},{date: '08/06', value: 446, orderNum: 75},{date: '08/07', value: 516, orderNum: 45},{date: '08/08', value: 116, orderNum: 18},{date: '08/09', value: 236, orderNum: 40},{date: '08/10', value: 129, orderNum: 14},{date: '08/11', value: 115, orderNum: 15},{date: '08/12', value: 306, orderNum: 45},{date: '08/13', value: 405, orderNum: 74},{date: '08/14', value: 187, orderNum: 10},{date: '08/15', value: 382, orderNum: 15},{date: '08/16', value: 224, orderNum: 40},{date: '08/17', value: 478, orderNum: 25},{date: '08/18', value: 256, orderNum: 25},{date: '08/19', value: 352, orderNum: 25},{date: '08/20', value: 172, orderNum: 25},{date: '08/21', value: 172, orderNum: 25},{date: '08/22', value: 172, orderNum: 32},{date: '08/23', value: 172, orderNum: 32},{date: '08/24', value: 172, orderNum: 32},{date: '08/25', value: 250, orderNum: 42},{date: '08/26', value: 210, orderNum: 38},{date: '08/27', value: 334, orderNum: 60},{date: '08/28', value: 412, orderNum: 80},{date: '08/29', value: 334, orderNum: 60},{date: '08/30', value: 252, orderNum: 48},{date: '08/31', value: 172, orderNum: 31}
]const xKeys = dataList.map((item) => item.date)
const values = dataList.map((item) => item.value)
const ordersList = dataList.map((item) => item.orderNum)
title
title: {text: '近30日用户订单数据',show: true,textStyle: {color: '#fff',fontSize: '36',fontFamily: 'Microsoft YaHei',fontWeight: 400},top: '42',left: '40'
}

在这里插入图片描述

legend (配合series才会显示)
legend: { // 图例组件展现了不同系列的标记(symbol),颜色和名字。可以通过点击图例控制哪些系列不显示top: 150,right: 20,z:4, // 组件的所有图形的z值。控制图形的前后顺序。z值小的图形会被z值大的图形覆盖data: ['登陆用户数', '下单次数'], // 图例的数据数组。数组项通常为一个字符串,每一项代表一个系列的 name(如果是饼图,也可以是饼图单个数据的 name)。图例组件会自动根据对应系列的图形标记(symbol)来绘制自己的颜色和标记,特殊字符串 ''(空字符串)或者 '\n'(换行字符串)用于图例的换行textStyle: {fontSize: '24px',fontFamily: 'Microsoft YaHei',fontWeight: 400,color: '#c2cbf2'}
}

在这里插入图片描述

grid
grid: { // 直角坐标系内绘图网格,单个 grid 内最多可以放置上下两个 X 轴,左右两个 Y 轴。可以在网格上绘制折线图,柱状图,散点图(气泡图)left: 30,top: 200,right: 30,bottom: 70
}

在这里插入图片描述

xAxis(直角坐标系 grid 中的 x 轴)
xAxis: [{type: "category",color: "#323E52",data: xKeys,axisLabel: {margin: 20, // 刻度标签与轴线之间的距离interval:'auto', // 坐标轴刻度标签的显示间隔,在类目轴中有效textStyle: {fontSize: 22,fontFamily: "Microsoft YaHei",fontWeight: 400,textAlign: "center",color: "#c2cbf2",},},axisLine: {lineStyle: {color: "#b7ccff",type: "solid",},},splitLine: {show: false,},},]

在这里插入图片描述

yAxis(直角坐标系 grid 中的 y 轴)
yAxis: [{ // 左边轴type: 'value',silent: true, // 坐标轴是否是静态无法交互interval: 100, // 强制设置坐标轴分割间隔   因为 splitNumber 是预估的值,实际根据策略计算出来的刻度可能无法达到想要的效果,这时候可以使用 interval 配合 min、max 强制设定刻度划分,一般不建议使用min: 0,max: 600,axisLable: {textStyle: {fontSize: 24,fontFamily: 'Microsoft YaHei',fontWeight: 400,textAlign: 'right',color: '#c2cbf2'}},axisLine: {show: false},axisTick: { // 坐标轴刻度相关设置show: false},splitLine: { // 坐标轴在 grid 区域中的分隔线show: true,lineStyle: {color: '#232842',type: 'solid'}}},{ // 右边轴type: 'value',position: 'right',silent: true,interval: 20,min: 0,max: 120,axisLable: {textStyle: {fontSize: 24,fontFamily: 'Microsoft YaHei',fontWeight: 400,textAlign: 400,color: '#c2cbf2'}},axisLine: {show: false},axisTick: {show: false},splitLine: {show: false}}
]

在这里插入图片描述

series(系列列表。每个系列通过 type 决定自己的图表类型)
series: [{name: '登陆用户数',type: 'bar',data: values,itemStyle: {color: '#6482ff',barBorderRadius: [10, 10, 0, 0]},label: {show: false}},{name: '下单次数',type: 'line',data: ordersList,yAxisIndex: 1, // 使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用symbol: 'emptyCircle', // 标记的图形symbolSize: 8,itemStyle: {color: '#24DEF3'},hoverAnimation: true // 是否开启 hover 在拐点标志上的提示动画效果}
]

在这里插入图片描述

修改部分问题(bug)

示例: 问题一

grid: {left: 'auto',top: 346, right: 'auto',containLabel:true,bottom: 20,},//grid这样写,左右都写成auto,还要加containLabel,不然就有可能挡住y轴的标签

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述


示例: 问题二

yAxis里面的max不能写死,不然最大值永远不会变,比如max=100,实际的值超过是200,那就会挡住

在这里插入图片描述
在这里插入图片描述


在这里插入图片描述

相信看了这篇文章,你应该会构建 柱状图(Mixed Line and Bar),觉得有用的话就给小编点个赞呗!!!

这篇关于【Echarts】详解 柱状图(Mixed Line and Bar)!!快来看看吧!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/319627

相关文章

一文深入详解Python的secrets模块

《一文深入详解Python的secrets模块》在构建涉及用户身份认证、权限管理、加密通信等系统时,开发者最不能忽视的一个问题就是“安全性”,Python在3.6版本中引入了专门面向安全用途的secr... 目录引言一、背景与动机:为什么需要 secrets 模块?二、secrets 模块的核心功能1. 基

一文详解MySQL如何设置自动备份任务

《一文详解MySQL如何设置自动备份任务》设置自动备份任务可以确保你的数据库定期备份,防止数据丢失,下面我们就来详细介绍一下如何使用Bash脚本和Cron任务在Linux系统上设置MySQL数据库的自... 目录1. 编写备份脚本1.1 创建并编辑备份脚本1.2 给予脚本执行权限2. 设置 Cron 任务2

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热

Python常用命令提示符使用方法详解

《Python常用命令提示符使用方法详解》在学习python的过程中,我们需要用到命令提示符(CMD)进行环境的配置,:本文主要介绍Python常用命令提示符使用方法的相关资料,文中通过代码介绍的... 目录一、python环境基础命令【Windows】1、检查Python是否安装2、 查看Python的安

HTML5 搜索框Search Box详解

《HTML5搜索框SearchBox详解》HTML5的搜索框是一个强大的工具,能够有效提升用户体验,通过结合自动补全功能和适当的样式,可以创建出既美观又实用的搜索界面,这篇文章给大家介绍HTML5... html5 搜索框(Search Box)详解搜索框是一个用于输入查询内容的控件,通常用于网站或应用程

Python中使用uv创建环境及原理举例详解

《Python中使用uv创建环境及原理举例详解》uv是Astral团队开发的高性能Python工具,整合包管理、虚拟环境、Python版本控制等功能,:本文主要介绍Python中使用uv创建环境及... 目录一、uv工具简介核心特点:二、安装uv1. 通过pip安装2. 通过脚本安装验证安装:配置镜像源(可

C++ 函数 strftime 和时间格式示例详解

《C++函数strftime和时间格式示例详解》strftime是C/C++标准库中用于格式化日期和时间的函数,定义在ctime头文件中,它将tm结构体中的时间信息转换为指定格式的字符串,是处理... 目录C++ 函数 strftipythonme 详解一、函数原型二、功能描述三、格式字符串说明四、返回值五

LiteFlow轻量级工作流引擎使用示例详解

《LiteFlow轻量级工作流引擎使用示例详解》:本文主要介绍LiteFlow是一个灵活、简洁且轻量的工作流引擎,适合用于中小型项目和微服务架构中的流程编排,本文给大家介绍LiteFlow轻量级工... 目录1. LiteFlow 主要特点2. 工作流定义方式3. LiteFlow 流程示例4. LiteF

CSS3中的字体及相关属性详解

《CSS3中的字体及相关属性详解》:本文主要介绍了CSS3中的字体及相关属性,详细内容请阅读本文,希望能对你有所帮助... 字体网页字体的三个来源:用户机器上安装的字体,放心使用。保存在第三方网站上的字体,例如Typekit和Google,可以link标签链接到你的页面上。保存在你自己Web服务器上的字

MySQL存储过程之循环遍历查询的结果集详解

《MySQL存储过程之循环遍历查询的结果集详解》:本文主要介绍MySQL存储过程之循环遍历查询的结果集,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言1. 表结构2. 存储过程3. 关于存储过程的SQL补充总结前言近来碰到这样一个问题:在生产上导入的数据发现