热门标签 | 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;
}


推荐阅读
  • Python正则表达式学习记录及常用方法
    本文记录了学习Python正则表达式的过程,介绍了re模块的常用方法re.search,并解释了rawstring的作用。正则表达式是一种方便检查字符串匹配模式的工具,通过本文的学习可以掌握Python中使用正则表达式的基本方法。 ... [详细]
  • vue使用
    关键词: ... [详细]
  • 本文介绍了闭包的定义和运转机制,重点解释了闭包如何能够接触外部函数的作用域中的变量。通过词法作用域的查找规则,闭包可以访问外部函数的作用域。同时还提到了闭包的作用和影响。 ... [详细]
  • PHP图片截取方法及应用实例
    本文介绍了使用PHP动态切割JPEG图片的方法,并提供了应用实例,包括截取视频图、提取文章内容中的图片地址、裁切图片等问题。详细介绍了相关的PHP函数和参数的使用,以及图片切割的具体步骤。同时,还提供了一些注意事项和优化建议。通过本文的学习,读者可以掌握PHP图片截取的技巧,实现自己的需求。 ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
  • 本文讨论了在Windows 8上安装gvim中插件时出现的错误加载问题。作者将EasyMotion插件放在了正确的位置,但加载时却出现了错误。作者提供了下载链接和之前放置插件的位置,并列出了出现的错误信息。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • 本文介绍了在Vue项目中如何结合Element UI解决连续上传多张图片及图片编辑的问题。作者强调了在编码前要明确需求和所需要的结果,并详细描述了自己的代码实现过程。 ... [详细]
  • 本文介绍了在wepy中运用小顺序页面受权的计划,包含了用户点击作废后的从新受权计划。 ... [详细]
  • 微软头条实习生分享深度学习自学指南
    本文介绍了一位微软头条实习生自学深度学习的经验分享,包括学习资源推荐、重要基础知识的学习要点等。作者强调了学好Python和数学基础的重要性,并提供了一些建议。 ... [详细]
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
  • 学习SLAM的女生,很酷
    本文介绍了学习SLAM的女生的故事,她们选择SLAM作为研究方向,面临各种学习挑战,但坚持不懈,最终获得成功。文章鼓励未来想走科研道路的女生勇敢追求自己的梦想,同时提到了一位正在英国攻读硕士学位的女生与SLAM结缘的经历。 ... [详细]
  • 本文介绍了brain的意思、读音、翻译、用法、发音、词组、同反义词等内容,以及脑新东方在线英语词典的相关信息。还包括了brain的词汇搭配、形容词和名词的用法,以及与brain相关的短语和词组。此外,还介绍了与brain相关的医学术语和智囊团等相关内容。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
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社区 版权所有