热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

vue项目中使用Echarts的一些总结,包括饼图,折现图,折柱混图,年月日切换

先奉上官网地址,一切以官网为主Echrts官网Echarts的基本使用安装cnpmiecharts-S全局使用在main.js中引入,然后用变量,

先奉上官网地址,一切以官网为主

Echrts官网

Echarts的基本使用


  • 安装

cnpm i echarts -S

  • 全局使用
    在main.js中引入,然后用变量,将其挂载到vue的原型上

import echarts from 'echarts'
Vue.prototype.$echarts = echarts

在组件中,就可以直接使用

this.$echarts.init()

稍后会说按需引入

下面来说一个我在项目中的总结


先看这个图 折柱混合

在这里插入图片描述

  • 首先是对数据的处理
    我们首先是要在页面画这么一个图,那么肯定是在mounted中执行的,但是画你得有数据,所有就把请求图表数据的方法,放在请求整体页面方法之后,然后把数据,当参数整体传给画图方法
    在这里插入图片描述
  • 下面就是使用map方法,对传入的数据,进行填充渲染

weeklyEcharts(data) { // 形参接收数据let myEchartWeekly = this.$echarts.init(document.getElementById("weeklyEcharts"));let optionWeekly = {tooltip: {trigger: "axis", },grid: {left: "3%",right: "4%",bottom: "8%",containLabel: true, }, // 整体gird表示图的位置legend: {x: "center",y: "bottom",itemHeight: 8,itemWidth: 8,}, // legend表示文字的样式,位置。itemHeight和itemWidth相等,表示的就是正方形color: ["#218AFF", "#47B8D9"], // 文字的颜色xAxis: [ // x坐标的相关配置{type: "category",data: data.map((item) => item.date), // 对数据的渲染axisPointer: { // 鼠标移入的效果type: "line", // 线lineStyle: {color: "#6b6b6b", // 线的颜色type: "solid", // width: 40,},},axisTick: { // x轴是否显示刻度线show: false,},axisLine: { // 是否显示x轴最下面的线,以及线的样式show: true,lineStyle: {color: "#818286",},},},],yAxis: [ // 由于是折柱混合,所以要有两个y轴,那么就要对两个y轴进行属性样式设定{ // 左边y轴type: "value",axisLabel: { // y轴的坐标formatter: function (value) {return value + "MH/s";},},axisTick: {show: false,}, // 是否显示刻度线splitLine: {show: true,lineStyle: {type: 'dashed'}}, //画y轴的线axisLine: {show: false, // y轴最左边的线是否显示lineStyle: {color: "#989898", // y轴最左边的单位的样式},},// y轴最左边的线的样式},// y轴右边线的样式,和左边同理{type: "value",axisTick: {show: false,},axisLine: {show: false,lineStyle: {color: "#989898",},},splitLine: {show: true,lineStyle: {type: 'dashed'}},axisLabel: {formatter: function (value) {return value;},},},],series: [ // 圆柱和曲线的绘制{name: "算力",type: "bar", // 圆柱color: "#1362FE",barWidth: 40, // 圆柱的宽// stack: '1',itemStyle: { // 圆柱的样式//柱形图圆角,鼠标移上去效果,如果只是一个数字则说明四个参数全部设置为那么多emphasis: {barBorderRadius: 30,// barBorderColor: "rgba(0,0,0,0)",// color: "rgba(0,0,0,0)",},normal: {//柱形图圆角,初始化效果barBorderRadius: [6, 6, 0, 0],marginBottom: 20,// barBorderColor: "rgba(0,0,0,0)",// color: "rgba(0,0,0,0)",},},data: data.map((item) => (item.hashrate / 1000000).toFixed(2)), // 圆柱数据的渲染},{// 折现的渲染配置name: "收益",color: "#FB7829",type: "line", //线smooth: true, // 光滑symbol: "none",// 鼠标滑过,是否显示小圆点yAxisIndex: 1, // 不重叠,如果是多个图,可以给yAxisIndex分别设置1,2,3,....data: data.map((item) =>(item.amount / 1000000000000000000).toFixed(5)), // 折现的数据渲染},],};myEchartWeekly.setOption(optionWeekly); // 通过setOption这个方法,将配置好的参数(optionWeekly),绘制到画板(myEchartWeekly)上.},

  • 以上就是对折柱绘制的总结。我最欣赏的,不是他的参数配置,而是图标数据,作为整个参数传递。最后在图表中,利用map去一个一个取值

双折线图

在这里插入图片描述

  • 上代码

earnEcharts(data) {let myEchartLine = this.$echarts.init(document.getElementById("earnEcharts"));let optionLine = {tooltip: {trigger: "axis",},legend: {x: "center",y: "bottom",padding: [0, 0, 0, 0],data: [{ name: "收益", icon: "rect" },{ name: "均值", icon: "rect" }, // icon 可以设置文字前图标的类型],itemHeight: 8, // 设置图标宽高,其实设置宽高一直,那不就是正方形了么itemWidth: 8,},color: ["rgba(17, 99, 255)", "rgba(243, 122, 44)"],grid: {left: "3%",right: "4%",bottom: "7%",containLabel: true,},xAxis: {type: "category",boundaryGap: false,data: data.map((item) => { // 对x轴数据的处理let date = new Date(item.time * 1000); //当你出现了Invalid date,使用时间 * 1000或者加上.unix(+res)return this.$moment(date).format("MM-DD hh:00");}),axisLabel: { // 对坐标值的处理interval: 50,formatter: (value, idx) => {var date = new Date(value);return this.$moment(date).format("MM-DD hh:00");},},axisTick: {show: false,},axisLine: {show: false,lineStyle: {color: "#989898",},},},axisTick: {show: false,},axisLine: {show: false,lineStyle: {color: "#989898",},},},yAxis: {type: "value",axisLine: {show: false,lineStyle: {color: "#989898",},},axisTick: {show: false,},},series: [{name: "收益",type: "line",stack: "总量",smooth: true,symbol: "none", //取消折点圆圈areaStyle: {color: "rgba(17, 99, 255, 0.2)"},data: data.map((item) => {return item.amount;}),itemStyle: {normal: {lineStyle: {color: "#218AFF",width: 0.5},},},},{name: "均值",type: "line",stack: "总量", // 这个是不要的,我留了一个bug。这个总量是会叠加的,在这一条折线里,我们需要的是单个折现的数据。所以应该把stack去掉smooth: true,symbol: "none", //取消折点圆圈areaStyle: {color: "rgba(243, 122, 44, 0.2)"}, // 折现下面的阴影部分data: data.map((item) => {return item.meanAmount;}),itemStyle: {normal: {lineStyle: {color: "#47B8D9",width: 0.5},},},},],};myEchartLine.setOption(optionLine);},

双折现图的难点在于对数据的处理,后端返回的数据是这样的
在这里插入图片描述
他要实时的时间所对应的数据,来描绘图标,但是图标展示却是这样的
在这里插入图片描述

  • 接下来就直接看对数据的处理了,
  • 要求是只要格式是 月-日 时:00 ,我这里用了moment,
  • this.$moment(date).format(“MM-DD hh:00”) 这样就可以转化成自己想要的格式

axisLabel: {interval: 50, // 坐标的间隔值。这个值,会自动排间隔,你想坐标上放两个间隔坐标值,那你间隔就大一下,这个是自适应的。formatter: (value) => {var date = new Date(value);return this.$moment(date).format("MM-DD hh:00");},},

我这是整体用的插件

安装 momen

cnpm i moment -S

-在main.js中导入,并且挂载到vue原型上

import echarts from 'echarts'
Vue.prototype.$moment = moment;//赋值使用

均值是0.01所以这个图应该是这样的
在这里插入图片描述

下面再来看一个图,这个图也是两根折现,但是他是年月日切换的

在这里插入图片描述

  • 图跟下面日期就不多上了,上一个图已经详细说明。这个图将说说年月日切换这个
  • 首先要明白,年月日切换也是调接口,所以现在问题就变得异常简单,点击年月日,传不同的参数给图表接口,那倒数据,渲染即可
    上代码
  • 点击切换日期代码

<div class&#61;"data-main-nyr"><p&#64;click&#61;"getIsActive(1, 1)":class&#61;"[isactive &#61;&#61; 1 ? &#39;data-main-nyr-p&#39; : &#39;&#39;]"></p><p&#64;click&#61;"getIsActive(2, 1)":class&#61;"[isactive &#61;&#61; 2 ? &#39;data-main-nyr-p&#39; : &#39;&#39;]"></p><p&#64;click&#61;"getIsActive(3, 1)":class&#61;"[isactive &#61;&#61; 3 ? &#39;data-main-nyr-p&#39; : &#39;&#39;]"></p></div>

  • 逻辑代码

getIsActive(i, index) {if (index &#61;&#61; 1) {this.isactive &#61; i;} else {this.isactive1 &#61; i;}if (i &#61;&#61; 1) {this.getStatisticsList("d", index);} else if (i &#61;&#61; 2) {this.getStatisticsList("w", index);} else {this.getStatisticsList("m", index);}},// 根据年月日请求数据getStatisticsList(index, i) {getStatistics({ zoom: index },(res) &#61;> {if (i &#61;&#61; 1) {this.manyLine(res.data.data, index);} else if (i &#61;&#61; 0) {this.manyLine1(res.data.data, index);} else {this.manyLine(res.data.data, index);this.manyLine1(res.data.data, index);}},(err) &#61;> {console.log(err);});},

饼图

在这里插入图片描述

drawChart(datalist) {const myEchart &#61; echarts.init(document.getElementById("main"));const option &#61; {tooltip: {trigger: "item", },color: ["rgba(30, 208, 160, 1)", "rgba(247, 122, 41, 1)", "red"],series: [{name: "份额",type: "pie",radius: ["54%", "70%"],avoidLabelOverlap: false,label: {show: false,position: "center",},labelLine: {show: false,},data: [{ value: datalist.valid_shares24h, name: "有效份额" },{ value: datalist.stale_shares24h, name: "延迟份额" },{ value: datalist.invalid_shares24h, name: "无效份额" },],},],};myEchart.setOption(option);},

  • 这个饼图也没啥说的&#xff0c;就是中间的那个状态。我们是根据右侧的数据&#xff0c;来展示饼图里面显示的文字。所以需要做个数据处理,并且样式需要定位

.share-main-photo {position: absolute;left: 60px;top: 110px;display: flex;flex-direction: column;align-items: center;justify-content: center;
}

<p>健康度</p><p>{{(datalist.valid_shares24h / datalist.all) * 100 >&#61; 90? "极好": (datalist.valid_shares24h / datalist.all) * 100 >&#61; 70? "良好": (datalist.valid_shares24h / datalist.all) * 100 >&#61; 50? "较差": "极差"}}</p>

横条展示&#xff0c;类似于百分比&#xff0c;这个是自己实现的

在这里插入图片描述

首先实现一个全红的样式横条&#xff0c;然后里面的样式&#xff0c;通过计算来实现

<div class&#61;"line-red"><pclass&#61;"line-green":style&#61;"{ width: parseInt((2 / (2 &#43; 8)) * 410) &#43; &#39;px&#39; }"></p></div>

.line-red {margin-top: 6px;margin-right: 20px;height: 26px;background: #f71664;
}
.line-green {height: 26px;background: #21ce9d;
}


推荐阅读
  • 本文介绍了在wepy中运用小顺序页面受权的计划,包含了用户点击作废后的从新受权计划。 ... [详细]
  • vue使用
    关键词: ... [详细]
  • 本文介绍了闭包的定义和运转机制,重点解释了闭包如何能够接触外部函数的作用域中的变量。通过词法作用域的查找规则,闭包可以访问外部函数的作用域。同时还提到了闭包的作用和影响。 ... [详细]
  • 生成式对抗网络模型综述摘要生成式对抗网络模型(GAN)是基于深度学习的一种强大的生成模型,可以应用于计算机视觉、自然语言处理、半监督学习等重要领域。生成式对抗网络 ... [详细]
  • 不同优化算法的比较分析及实验验证
    本文介绍了神经网络优化中常用的优化方法,包括学习率调整和梯度估计修正,并通过实验验证了不同优化算法的效果。实验结果表明,Adam算法在综合考虑学习率调整和梯度估计修正方面表现较好。该研究对于优化神经网络的训练过程具有指导意义。 ... [详细]
  • 本文介绍了机器学习手册中关于日期和时区操作的重要性以及其在实际应用中的作用。文章以一个故事为背景,描述了学童们面对老先生的教导时的反应,以及上官如在这个过程中的表现。同时,文章也提到了顾慎为对上官如的恨意以及他们之间的矛盾源于早年的结局。最后,文章强调了日期和时区操作在机器学习中的重要性,并指出了其在实际应用中的作用和意义。 ... [详细]
  • 本文讨论了编写可保护的代码的重要性,包括提高代码的可读性、可调试性和直观性。同时介绍了优化代码的方法,如代码格式化、解释函数和提炼函数等。还提到了一些常见的坏代码味道,如不规范的命名、重复代码、过长的函数和参数列表等。最后,介绍了如何处理数据泥团和进行函数重构,以提高代码质量和可维护性。 ... [详细]
  • 本文由编程笔记#小编为大家整理,主要介绍了logistic回归(线性和非线性)相关的知识,包括线性logistic回归的代码和数据集的分布情况。希望对你有一定的参考价值。 ... [详细]
  • Metasploit攻击渗透实践
    本文介绍了Metasploit攻击渗透实践的内容和要求,包括主动攻击、针对浏览器和客户端的攻击,以及成功应用辅助模块的实践过程。其中涉及使用Hydra在不知道密码的情况下攻击metsploit2靶机获取密码,以及攻击浏览器中的tomcat服务的具体步骤。同时还讲解了爆破密码的方法和设置攻击目标主机的相关参数。 ... [详细]
  • baresip android编译、运行教程1语音通话
    本文介绍了如何在安卓平台上编译和运行baresip android,包括下载相关的sdk和ndk,修改ndk路径和输出目录,以及创建一个c++的安卓工程并将目录考到cpp下。详细步骤可参考给出的链接和文档。 ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • Go GUIlxn/walk 学习3.菜单栏和工具栏的具体实现
    本文介绍了使用Go语言的GUI库lxn/walk实现菜单栏和工具栏的具体方法,包括消息窗口的产生、文件放置动作响应和提示框的应用。部分代码来自上一篇博客和lxn/walk官方示例。文章提供了学习GUI开发的实际案例和代码示例。 ... [详细]
  • 本文详细介绍了如何使用MySQL来显示SQL语句的执行时间,并通过MySQL Query Profiler获取CPU和内存使用量以及系统锁和表锁的时间。同时介绍了效能分析的三种方法:瓶颈分析、工作负载分析和基于比率的分析。 ... [详细]
  • WhenIusepythontoapplythepymysqlmoduletoaddafieldtoatableinthemysqldatabase,itdo ... [详细]
  • 【shell】网络处理:判断IP是否在网段、两个ip是否同网段、IP地址范围、网段包含关系
    本文介绍了使用shell脚本判断IP是否在同一网段、判断IP地址是否在某个范围内、计算IP地址范围、判断网段之间的包含关系的方法和原理。通过对IP和掩码进行与计算,可以判断两个IP是否在同一网段。同时,还提供了一段用于验证IP地址的正则表达式和判断特殊IP地址的方法。 ... [详细]
author-avatar
RealMadrid
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有