首页 > 其他分享 >vue中echarts图表---正负轴柱状图

vue中echarts图表---正负轴柱状图

时间:2023-12-14 10:25:30浏览次数:38  
标签:vue color data value --- 柱状图 seriesYears echarts

一、安装

npm i echarts--save

二、引入

//全局引入
import echarts from 'echarts'
Vue.prototype.$echarts = echarts

//局部【这里使用局部引入】
import echarts from 'echarts';

三、代码

  1 <!-- 容器 -->
  2 <div id="cylinderEcharts" ref="cylinderEcharts" style="width:900px;height:500px"></div>
  3 
  4 <script>
  5 import echarts from 'echarts';
  6 export default {
  7 data() {
  8   return{
  9      // 正负柱状图
 10       zhengfuZhu: {},
 11       data1: [],
 12       data2: [],
 13       data3: [],
 14       data4: [],
 15       xAxisData1: [],//横轴刻度
 16       seriesLabel: { //柱子上的字体
 17         show: false,
 18         position: 'outside',
 19         color: '#BEC3EB',
 20       },
 21       seriesEmphasis: { //
 22         itemStyle: {
 23           shadowBlur: 20,
 24           shadowColor: 'rgba(0,0,0,0.3)'
 25         }
 26       },
 27       seriesBarWidth: 17,//设置柱子粗细
 28       seriesYears: ['2022', '2023'],
 29       seriesColors: ['#5871c0', '#9eca7f', '#f3c96b', '#de6e6a'],
 30   }  
 31 },
 32 mounted() {
 33         for (let i = 0; i < 12; i++) {
 34             this.xAxisData1.push(i + 1 + "月");
 35             this.data1.push(+(Math.random() * 200).toFixed(2));
 36             this.data3.push(+(Math.random() * 500).toFixed(2));
 37             this.data2.push(-(Math.random() + 300).toFixed(2));
 38             this.data4.push(-(Math.random() + 100).toFixed(2));
 39           }
 40           this.$nextTick(() => { //加这这防止容器还未出来,就去初化下,会报如下错误
 41             this.drawLine();
 42           })
 43 },
 44 methods: {
 45    drawLine(){
 46       this.zhengfuZhu = {
 47         legend: {
 48           data: [`${this.seriesYears[0]}计划完成任务`, `${this.seriesYears[0]}实际完成任务`,
 49           `${this.seriesYears[1]}计划完成任务`, `${this.seriesYears[1]}实际完成任务`],
 50           right: '10%',
 51           icon: 'circle',
 52           textStyle: {
 53             color: ' #BEC3EB',
 54             fontSize: 13
 55           },
 56           itemWidth: 12, // 设置宽度
 57           itemHeight: 12, // 设置高度
 58           itemGap: 15,
 59           formatter: function (value) {
 60             return value
 61           },
 62         },
 63         tooltip: {
 64           formatter: function (params) {
 65             var value = params.value;
 66             //首先要看看params是怎样的数据结构,里面有什么内容;
 67             if (value < 0) {
 68                 value = -value
 69             }
 70             return params.seriesName + ':' + value + ''
 71           }
 72         },
 73         xAxis: {
 74           data: this.xAxisData1,
 75           splitArea: { show: false },
 76           axisLabel: {
 77             textStyle: {
 78               color: '#5871c0',
 79               fontSize: 13
 80             },
 81           },
 82         },
 83         yAxis: [
 84           {
 85             type: 'value',
 86             splitNumber: 10,
 87             splitLine: {
 88               show: true, lineStyle: {
 89                 color: '#6469A1',
 90                 width: 1,
 91                 type: 'solid'
 92               }
 93             },
 94             axisLabel: {
 95               formatter: function (value) {
 96                 // Function formatter
 97                 if (value < 0) {
 98                     value = -value
 99                 } else {
100                     value = value
101                 }
102                 return value + ''
103               },
104               textStyle: {
105                   color: ' #BEC3EB',
106                   fontSize: 13
107               },
108             },
109           }],
110         grid: {
111           bottom: 25,
112           top: 35,
113           right: 0
114         },
115         series: [
116           {
117             name: `${this.seriesYears[0]}计划完成任务`,
118             type: 'bar',
119             stack: 'one',
120             label: this.seriesLabel,
121             emphasis: this.seriesEmphasis,
122             data: this.data1,
123             barWidth: this.seriesBarWidth,
124             itemStyle: {
125               // 柱状图颜色
126               color: this.seriesColors[0]
127             }
128           },
129           {
130             name: `${this.seriesYears[0]}实际完成任务`,
131             type: 'bar',
132             label: this.seriesLabel,
133             stack: 'two',
134             emphasis: this.seriesEmphasis,
135             barWidth: this.seriesBarWidth,
136             data: this.data3,
137             itemStyle: {
138             // 柱状图颜色
139             color: this.seriesColors[1]
140             }
141           },
142           {
143             name: `${this.seriesYears[1]}实际完成任务`,
144             type: 'bar',
145             label: this.seriesLabel,
146             stack: 'one',
147             emphasis: this.seriesEmphasis,
148             data: this.data2,
149             barWidth: this.seriesBarWidth,
150             itemStyle: {
151               // 柱状图颜色
152               color: this.seriesColors[2]
153             }
154           },
155           {
156             name: `${this.seriesYears[1]}计划完成任务`,
157             type: 'bar',
158             label: this.seriesLabel,
159             stack: 'two',
160             emphasis: this.seriesEmphasis,
161             barWidth: this.seriesBarWidth,
162             data: this.data4,
163             itemStyle: {
164               // 柱状图颜色
165               color: this.seriesColors[3]
166             }
167           },
168         ],
169       }
170       console.log('this.$refs.cylinderEcharts--',document.getElementById('cylinderEcharts'));
171       var myChart2 = echarts.init(this.$refs.cylinderEcharts);//echarts.init(document.getElementById('cylinderEcharts'));
172       myChart2.setOption(this.zhengfuZhu);
173     }, 
174 }
175 
176 }
177 
178 
179 </script> 

 一定要等容器加载出来,再去初始化图表,要不然会报如下错误

最终效果如下

 参考文章:https://blog.csdn.net/qq_41579104/article/details/132023123

标签:vue,color,data,value,---,柱状图,seriesYears,echarts
From: https://www.cnblogs.com/tanweiwei/p/17900562.html

相关文章

  • 【2023-12-13】一定困难
    20:00如果他们的目的是共同成就的协作,那么此时的爱就是祝福,美妙得如同灵魂深处的诗歌。如果他们在合作中表现出气馁、怀疑和退出,那么爱就会成为魔鬼的工具,毁灭我们的责任和体面。                              ......
  • 深度学习3D网络---PointNet++
    PointNet++地址:http://stanford.edu/~rqi/pointnet2/1.两者主要不同点考虑到PointNet特征提取时只考虑单点,不能很好的表示局部结构==>PointNet++引入了sampling&grouping,考虑局部领域特征PointNet中globalfeature直接由maxpool得到,容易造成信息丢失==>PointNet++采......
  • ChatGLM2-6B模型的微调
    概述GLM、ChatGLM的相关基础知识说明:GLM模型底层还是基于Transformer,因此其设计、优化都是围绕Transformer的各个组件的。从注意力层的掩码、位置编码等方面优化与设计。ChatGLM3/ChatGLM2的源码中,比如finetune、trainer等代码,其实是copy自HuggingFace,而且其使用流程与调用机......
  • 子类父类有相同的方法优先调用子类-重写-递归
    子类和父类有相同的方法,优先调用子类。如果子类没有,父类。packagestudyDemo9yue;publicclassstudy01{ publicstaticvoidmain(String[]args){ Sons1=newSon(); s1.test(); }}classFather{ voidtest(){ System.out.println("我是父类的test"); }}c......
  • 第1-14届河南省大学生程序设计竞赛(ICPC-ACM河南省赛)
    河南省大学生程序设计竞赛又称为河南省内的ACM,是河南省内大学生程序设计的盛宴  2021年5月22日至23日,河南省第十三届大学生程序设计竞赛在  河南农业大学举行,2022年 4月16日,中原工学院我院2022年(第14届)ACM程序设计竞赛决赛在学院基础实验楼举行。5月20日至21日,2023年......
  • windows安装tensorflow-gpu / CUDA / cuDNN
    最终安装内容:windows10+3060显卡+tensorflow-gpu2.10.0+CUDA11.2+cuDNN8.1 1.命令行输入nvidia-smi,查看显卡对应的cuda版本。如下图,CUDAVersion为12.1,则安装的CUDA版本不能高于12.1。 2.Nvidia官网查看tensorflow-gpu和CUDA的版本对应关系。注意:语言一定要切......
  • C++基础 -6- 二维数组,数组指针
    ———————二维数组,数组指针——————— ......
  • 界面控件DevExpress .NET MAUI v23.1 - 发布一系列新组件
    DevExpress拥有.NET开发需要的所有平台控件,包含600多个UI控件、报表平台、DevExpressDashboardeXpressApp框架、适用于VisualStudio的CodeRush等一系列辅助工具。屡获大奖的软件开发平台DevExpress今年第一个重要版本v23.1正式发布,该版本拥有众多新产品和数十个具有高影响力......
  • 数据分析--数据预处理
    本文主要是个人的学习笔记总结,数据预处理的基本思路和方法,包括一些方法的使用示例和参数解释,具体的数据预处理案例case详见其他文章。如有错误之处还请指正!目录数据的质量评定数据处理步骤缺失值的处理标记缺失值删除缺失值填充缺失值重复值处理异常值的处理数据集合并pandas.Dat......
  • 最强Pose模型RTMO开源 | 基于YOLO架构再设计,9MB+9ms性能完爆YOLO-Pose
    https://mp.weixin.qq.com/s/4EJAKBcqlCzDXib1_TKJxw点击下方卡片,关注「AI视界引擎」公众号AI视界引擎「AI视界引擎」公众号不仅致力于分享AI视觉与大语言模型的前沿科技,还将成为连接业界专家、学术界和广大读者的桥梁。我们将提供最新的研究进展、技术突破、应用案例以......