目录

前言:

1.圆环图表

效果如下所示:

思路:

组件代码:

2. 饼图封装

效果如下所示 :

组件代码如下:

3.柱状图封装

效果图如下:

组件核心配置项如下:

4 折线图封装

效果如下:

配置项:


前言:

以下的代码基于echarts+vue2,我使用的echarts版本是5.3,但是实测更低或更高均可使用。以下组件均已封装。


1.圆环图表


效果如下所示:

思路:

基于阴影(box-shadow),修改shadowBlur的值


组件代码:

<template><div id="keyleft1" style="height: 200px; width: 200px">{{ leftOne }}</div>
</template><script>
import 'echarts-gl'
export default {props: {leftOne: {type: String,default: "0"},},data () {return {numX: "0"}},methods: {init () {let _that = thisvar chartDom = document.getElementById("keyleft1")var myChart = this.$echarts.init(chartDom)var optionvar trafficWay = [{name: '',value: 20}, {name: '',value: 10}, {name: '',value: 30}]var data = []var color = ['#00ffff', '#ff0', '#006ced', '#ffe000', '#ffa800', '#ff5b00', '#ff3000']for (var i = 0; i < trafficWay.length; i++) {data.push({value: trafficWay[i].value,name: trafficWay[i].name,itemStyle: {label: {normal: {show: false}},normal: {borderWidth: 5,shadowBlur: 20,borderColor: color[i],shadowColor: color[i]}}}, {value: 2,name: '',itemStyle: {normal: {label: {show: false},labelLine: {normal: {show: false}},color: 'rgba(0, 0, 0, 0)',borderColor: 'rgba(0, 0, 0, 0)',borderWidth: 0}}})}var seriesOption = [{name: '',type: 'pie',clockWise: false,radius: [65, 60],hoverAnimation: false,itemStyle: {normal: {label: {show: false,position: 'outside',color: '#ddd',formatter: function (params) {var percent = 0var total = 0for (var i = 0; i < trafficWay.length; i++) {total += trafficWay[i].value}percent = ((params.value / total) * 100).toFixed(0)if (params.name !== '') {return params.name + '\n' + '\n' + '占百分比:' + percent + '%'} else {return ''}},},labelLine: {length: 30,length2: 100,show: true,color: '#00ffff'}}},data: data}]option = {backgroundColor: 'rgba(255,255,255,0)',color: color,title: {text: _that.numX,subtext: '',top: '46%',textAlign: "center",left: "49%",textStyle: {color: '#fff',fontSize: 20,fontWeight: '600'},subtextStyle: {color: '#fff',fontSize: 18,fontWeight: '400'}},tooltip: {show: false},legend: {icon: "circle",orient: 'horizontal',// x: 'left',data: ['功能区域噪声', '交通噪声', '区域噪声'],right: 250,top: 100,align: 'right',textStyle: {color: "#fff"},itemGap: 20},toolbox: {show: false},series: seriesOption}option && myChart.setOption(option)}},mounted () {this.init()},watch: {leftOne (newValue, oldValue) {this.numX = newValuethis.init()}},
}
</script><style>
</style>

2. 饼图封装

效果如下所示 :


组件代码如下:

<template><div id="left2" style="height: 280px"></div>
</template><script>
import 'echarts-gl'
export default {props: {leftTwoData: {type: String,default: "0"},},data () {return {numX: "0"}},methods: {init () {let _that = thisvar chartDom = document.getElementById('left2')var myChart = this.$echarts.init(chartDom)var optionvar img =""let arrD = []for (const key in _that.numX) {if (Object.hasOwnProperty.call(_that.numX, key)) {const element = _that.numX[key]arrD.push({name: key,value: element,})}}var trafficWay = [{name: "火",value: 2,},{name: "飞机",value: 10,},{name: "客车",value: 30,},{name: "轮渡",value: 40,},] || arrDvar data = []var color = ["#00ffff","#00cfff","#006ced","#ffe000","#ffa800","#ff5b00","#ff3000",]for (var i = 0; i < trafficWay.length; i++) {data.push({value: trafficWay[i].value,name: trafficWay[i].name,itemStyle: {normal: {borderWidth: 5,shadowBlur: 20,borderColor: color[i],shadowColor: color[i],},},},{value: 2,name: "",itemStyle: {normal: {label: {show: false,},labelLine: {show: false,},color: "rgba(0, 0, 0, 0)",borderColor: "rgba(0, 0, 0, 0)",borderWidth: 0,},},})}var seriesOption = [{name: "",type: "pie",clockWise: false,radius: [105, 109],hoverAnimation: false,itemStyle: {normal: {label: {show: true,position: "outside",color: "#ddd",formatter: function (params) {var percent = 0var total = 0for (var i = 0; i < trafficWay.length; i++) {total += trafficWay[i].value}percent = ((params.value / total) * 100).toFixed(0)if (params.name !== "") {return ("" +params.name +"\n" +"\n" +"" +percent +"%")} else {return ""}},},labelLine: {length: 30,length2: 10,show: true,color: "#00ffff",},},},data: data,},]option = {backgroundColor: "rgba(255,255,255,0)",color: color,title: {text: "交通方式",top: "48%",textAlign: "center",left: "49%",textStyle: {color: "#fff",fontSize: 22,fontWeight: "400",},},graphic: {elements: [{type: "image",z: 3,style: {image: img,width: 178,height: 178,},left: "center",top: "center",position: [100, 100],},],},tooltip: {show: false,},legend: {show: false,icon: "circle",orient: "horizontal",// x: 'left',data: ["火车", "飞机", "客车", "轮渡"],right: 10,bottom: 0,align: "right",textStyle: {color: "#fff",},itemGap: 10,},toolbox: {show: false,},series: seriesOption,}option && myChart.setOption(option)}},mounted () {this.init()},watch: {leftTwoData (newValue, oldValue) {this.numX = JSON.parse(newValue)this.init()console.log("leftTwoData---------", this.numX)}},
}
</script><style>
</style>

3.柱状图封装

效果图如下:


由于和上面的改动不算大,所以只贴核心配置项了。

组件核心配置项如下:

data = [{name: "常规",value: 175.17,},{name: "紧急",value: 148.35,},{name: "疑难",value: 95.36,},
];
xAxisData = [];
seriesData1 = [];
sum = 0;
barTopColor = ["#02c3f1", "#53e568", "#a154e9"];
barBottomColor = ["rgba(2,195,241,0.1)","rgba(83, 229, 104, 0.1)","rgba(161, 84, 233, 0.1)",
];
data.forEach((item) => {xAxisData.push(item.name);seriesData1.push(item.value);sum += item.value;
});
option = {backgroundColor: "#061326",title: {text: "多色立体圆柱",top: 20,left: "center",textStyle: {color: "#fff",fontSize: 20,},},grid: {top: "25%",bottom: "15%",},xAxis: {data: xAxisData,axisTick: {show: false,},axisLine: {show: false,},axisLabel: {show: true,margin: 25,align: "center",formatter: function (params, index) {return ("{a|" +((seriesData1[index] / sum) * 100).toFixed(2) +"%}" +"\n" +"{b|" +params +"}");},textStyle: {fontSize: 14,color: "#ffffff",rich: {a: {fontSize: 12,color: "#ffffff",},b: {height: 20,fontSize: 14,color: "#ffffff",},},},},interval: 0,},yAxis: {splitLine: {show: false,},axisTick: {show: false,},axisLine: {show: false,},axisLabel: {show: false,},},series: [{name: "柱顶部",type: "pictorialBar",symbolSize: [26, 10],symbolOffset: [0, -5],z: 12,itemStyle: {normal: {color: function (params) {return barTopColor[params.dataIndex];},},},label: {show: true,position: "top",fontSize: 16,},symbolPosition: "end",data: seriesData1,},{name: "柱底部",type: "pictorialBar",symbolSize: [26, 10],symbolOffset: [0, 5],z: 12,itemStyle: {normal: {color: function (params) {return barTopColor[params.dataIndex];},},},data: seriesData1,},{name: "第一圈",type: "pictorialBar",symbolSize: [47, 16],symbolOffset: [0, 11],z: 11,itemStyle: {normal: {color: "transparent",borderColor: "#3ACDC5",borderWidth: 2,},},data: seriesData1,},{name: "第二圈",type: "pictorialBar",symbolSize: [62, 22],symbolOffset: [0, 17],z: 10,itemStyle: {normal: {color: "transparent",borderColor: barTopColor[0],borderWidth: 2,},},data: seriesData1,},{type: "bar",itemStyle: {normal: {color: function (params) {return new echarts.graphic.LinearGradient(0, 0, 0, 1, [{offset: 1,color: barTopColor[params.dataIndex],},{offset: 0,color: barBottomColor[params.dataIndex],},]);},opacity: 0.8,},},z: 16,silent: true,barWidth: 26,barGap: "-100%", // Make series be overlapdata: seriesData1,},],
};

4 折线图封装

效果如下:


配置项:

var lineColor = "#2F5384";
var labelColor = "#74BFE7";
var fontSize = "30";
option = {backgroundColor: "#000",grid: {left: "5%",right: "10%",top: "15%",bottom: "10%",containLabel: true,},tooltip: {show: true,trigger: "item",textStyle: {fontSize: fontSize,},},legend: {show: true,x: "center",y: "35",itemWidth: 45,itemHeight: 18,textStyle: {color: "#fff",fontSize: fontSize,},data: ["完成率"],},xAxis: [{type: "category",axisLabel: {color: labelColor,fontSize: fontSize,},axisLine: {show: true,lineStyle: {color: lineColor,width: 2,},},axisTick: {show: false,},splitLine: {show: false,lineStyle: {color: "#195384",},},data: ["1", "2", "3", "4", "5", "6", "7", "8", "9", "10", "11", "12"],},],yAxis: [{type: "value",name: "(%)",nameTextStyle: {fontSize: fontSize,color: "#fff",},axisLabel: {formatter: "{value}",textStyle: {color: labelColor,fontSize: fontSize,},},axisLine: {lineStyle: {color: lineColor,width: 2,},},axisTick: {show: false,},splitLine: {show: false,lineStyle: {color: "#142B57",},},},],series: [{name: "完成率",type: "line",stack: "总量",symbol: "circle",symbolSize: 10,smooth: true,itemStyle: {normal: {color: "rgba(3,240,254,1)",lineStyle: {color: "rgba(3,240,254,1)",width: 2,},areaStyle: {//color: '#94C9EC'color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{offset: 0,color: "rgba(3,240,254,.7)",},{offset: 1,color: "rgba(3,240,254,0)",},]),},shadowColor: "rgba(3,240,254,1)",shadowBlur: 20,},},markPoint: {itemStyle: {normal: {color: "red",},},},data: [120, 132, 101, 134, 90, 230, 210, 182, 191, 234, 290, 330],},],
};

【Echarts】封装几个酷炫(发光)图表相关推荐

  1. 一款简单、实时、酷炫的图表制作软件

    当今,图表制作已经成了每一个职场人的日常,如果列个职场基本傍身技能排行榜,图表制作怕是前三了.虽说它是工作日常,虽说它很重要,但很多人还是做不好图表. 比如,我们想象中的图表可能是这样的: 做出来的图 ...

  2. oracle 图表工具,一款简单、实时、酷炫的图表制作软件

    阅读提示: 文章中与FineReport软件使用的相关内容,基于软件的V7.0旧版本编写,不代表软件最新的使用方式. FineReport最新版免费试用:https://www.finereport. ...

  3. Excel作图太难看,掌握这7种酷炫可视化图表,老板直呼太牛了

    做汇报是打工人永远的痛,业绩差的时候领导把汇报方案从头骂到尾,业绩不错想在领导面前炫一下的时候,发现自己只会用Excel做难看的柱状图.折线图,就像下面这种,即使看得出业绩提升,但图表也确实拉垮. 其 ...

  4. FushionChart一个酷炫的图表插件

    FushionChart是一个关于图表的js插件.它能够把很多简单的图表用很酷很炫的方式显示在html中.它接受json,xml数据格式,我们只需要知道不同图表不同的数据格式就能够正确显示图表了.它操 ...

  5. Python可视化应用实战-如何制作酷炫的图表?

    前言 制作提供信息的可视化(有时称为绘图)是数据分析中的最重要任务之一.可视化可能是探索过程的一部分,例如,帮助识别异常值或所需的数据转换,或者为建模提供一些想法.对于其他人来说,构建网络交互式可视化 ...

  6. 使用 QuickBI 搭建酷炫可视化分析

    随着各行各业大数据的渗透,BI 类数据分析需求与日俱增,如何让可视化更好的展现数据的价值,是 BI 类产品一直努力的方向.对此国内外的BI产品都有自己的方法,如国外大牌的 PowerBI.Tablea ...

  7. 酷炫RGB LED立方体 (RP2040+WS2812)

    今天分享的项目详细介绍了一个酷炫发光的 Magic LED Cube的完整制作步骤,并开源了所有必要的设计文件.如果感兴趣的话,可以动手做一个,还可以自定义灯光动画展示方式,可作为一个独特的装饰摆件用 ...

  8. python可视化图表工具_酷炫的可视化图表工具来帮忙 深度评测五大Python数据可视化工具...

    原标题:酷炫的可视化图表工具来帮忙 深度评测五大Python数据可视化工具 不少Python用户的一大诉求是做出各种酷炫的可视化图表,而这就需要了解清楚工具特色,才好在制作不同类型图表顺利找到适合自己 ...

  9. vue 雷达扫描_GitHub - suneildve/vueDataV: 基于Vue + Echarts 构建的数据可视化平台,酷炫大屏展示模板和组件库,持续更新各行各业实用模板和炫酷小组件。...

    前言 一个基于Vue前端框架和第三方图表库echarts构建的可视化大数据平台,通过vue项目构建.指令的灵活运用.组件封装.组件之间通信,使内部图表组件库可实现自由替换和组合. 项目中部分前端库采用 ...

最新文章

  1. 用linux创建raid5,使用mdadm快速创建RAID5....(比赛后的小结!)
  2. 为了提高工作效率:通过pycharm的模板代码减少重复工作
  3. UI仿写 - 收藏集 - 掘金
  4. python3-正则表达式基本使用方法(附案例)_python正则表达式
  5. 接收大文件流_一文搞定 Node.js 流 (Stream)
  6. [转载][HASS.IO] 【HASSOS安装】成功安装HASSOS 1.9(避开了大部分坑版)
  7. VC2008配置设置(转)
  8. Revit二次开发——选集
  9. pdf打印机如何加密pdf文件?
  10. 关于左连接查询出现排序问题
  11. 计算机知识技能大赛总结,计算机技能大赛总结.doc
  12. 19年清北学堂冬令营游记
  13. 【软工作业思考】关于软工的一些概念性理解暨第一次阅读作业
  14. 重新加载script
  15. python的胶水特性是怎样出来的_为什么说python是胶水语言
  16. vue拖拽盒子;vue移动
  17. Jupyter离线安装部署
  18. 线性卷积、循环卷积、周期卷积的定义、计算方法及三者之间的关系
  19. [展览人周刊]华展云20170724期
  20. 计算机网络基础会话层,计算机网络体系结构及协议之会话层

热门文章

  1. 概率学派和贝叶斯学派的区别
  2. 详细介绍如何修改分区,各个分区作用,手机从出厂到使用的过程
  3. 下行参考信号——PDSCH DM-RS
  4. ExpRe[23] Oz[0] emacs初步,Hello world
  5. 基于pytorch构建双向LSTM(Bi-LSTM)文本情感分类实例(使用glove词向量)
  6. 好妈妈胜过好老师-爱和溺爱两件相反的事
  7. 拼多多APP商品详情接口获取activity_id值(拼多多activity_id接口)
  8. 太惊艳了,爆干几天几夜完成的实战模型:【猫狗大战】附资料
  9. 西部数码虚拟主机隐藏路由中的index.php
  10. android带指针仪表盘自动移动,Android 绘制仪表盘指针刻度