前言:现在大数据的表现形式越来越花里胡哨了;这篇文章收录了四个比较特别的Echarts图,标记了特点和重点;并且附源码(包含数据处理),组件可直接使用哟
图一
- 特点
- 立体柱状图
- 每个柱子颜色不同
- 重点
- 定义和柱子相同数量的颜色
- symbol : 'diamond'可以定义成自己想要的svg
/**
* @version 1.0.1
* @author yfeng
* @createTime:2021-08-01,
* @updateTime:2021-08-01
* @copyright thunisoft fd
*/
// 事件处理函数
export default {
props: {
// 需要传递的数据
data: {
type: Array,
default() {
return [{
name:'<60',
value:20
}, {
name:'60-79',
value:20
}, {
name:'80-99',
value:20
}, {
name:'100-120',
value:20
}, {
name:'>120',
value:20
}];
}
}
},
data() {
return {
// echarts对象
myEchart: null,
// 数据列表
dataList: [],
// echart的options
options: {},
colors:[
{
type: 'linear',
x: 0,
x2: 1,
y: 0,
y2: 0,
colorStops: [
{
offset: 0,
color: '#6fe0f0'
},
{
offset: 0.5,
color: '#6fe0f0'
},
{
offset: 0.5,
color: '#79ebb3'
},
{
offset: 1,
color: '#79ebb3'
}
]
},
{
type: 'linear',
x: 0,
x2: 1,
y: 0,
y2: 0,
colorStops: [
{
offset: 0,
color: '#a03db6'
},
{
offset: 0.5,
color: '#a03db6'
},
{
offset: 0.5,
color: '#6b23a9'
},
{
offset: 1,
color: '#6b23a9'
}
]
},
{
type: 'linear',
x: 0,
x2: 1,
y: 0,
y2: 0,
colorStops: [
{
offset: 0,
color: '#2ab1c1'
},
{
offset: 0.5,
color: '#2ab1c1'
},
{
offset: 0.5,
color: '#1a72e3'
},
{
offset: 1,
color: '#1a72e3'
}
]
},
{
type: 'linear',
x: 0,
x2: 1,
y: 0,
y2: 0,
colorStops: [
{
offset: 0,
color: '#d86781'
},
{
offset: 0.5,
color: '#d86781'
},
{
offset: 0.5,
color: '#942f9f'
},
{
offset: 1,
color: '#942f9f'
}
]
},
{
type: 'linear',
x: 0,
x2: 1,
y: 0,
y2: 0,
colorStops: [
{
offset: 0,
color: '#2f71e0'
},
{
offset: 0.5,
color: '#2f71e0'
},
{
offset: 0.5,
color: '#0e29a1'
},
{
offset: 1,
color: '#0e29a1'
}
]
}
]
};
},
// 创建元素
mounted() {
this.init();
},
// 销毁
destroyed() {
// 销毁图表
this.destroyedChart();
},
methods: {
// 设置默认参数
setDefaultOptions() {
const _this = this;
// 默认的参数
this.options = {
title: [{
show:true,
text: '单位:人',
left: '90%',
top: '6%',
textAlign: 'center',
textStyle: {
fontSize: '16',
fontWeight: 'normal',
color: '#dff6fc',
textAlign: 'center'
}
}],
legend: {show:false},
grid: {
top: '25%',
left: '5%',
bottom: '15%',
right: '0',
containLabel: true
},
xAxis: [
{
type: 'category',
axisTick: {show: false},
axisLine: {show: false},
offset:10,
axisLabel: {
textStyle: {
color: '#b9eff8',
fontWeight: 'normal',
fontSize: 16
},
align:'center',
interval:0
},
data: []
}
],
yAxis: [
{
show: true,
type: 'value',
min:0,
max:10,
axisLabel: {
textStyle: {
color: '#fff',
fontWeight: 'normal',
fontSize: 14
},
align:'center'
},
splitLine: {
show:true,
lineStyle: {color: 'rgba(74,92,138,0.5)'}
},
axisLine: {show: false}
}
],
series: [
{
z: 5,
name: 'top',
type: 'pictorialBar',
symbolPosition: 'end',
data: [],
cursor:'default',
symbolOffset: ['0', '-50%'],
symbol : 'diamond',
symbolSize: [20, 10],
itemStyle: {
normal: {
color: function (params) {
return _this.colors[params.dataIndex].colorStops[0].color;
}
}
},
label: {
show: true,
formatter: function (value) {
if (parseFloat(value.data)) {
return value.data;
}
return '';
},
position: 'top',
color: '#fff',
fontSize: 18,
textAlign: 'center'
}
}, {
z: 1,
type: 'bar',
name: 'jfkh',
barWidth: 20,
cursor:'default',
symbolPosition: 'end',
data: [],
itemStyle: {
normal: {
color: function (params) {
return _this.colors[params.dataIndex];
}
}
}
},
{
z: 1,
name: 'top',
type: 'pictorialBar',
symbolPosition: 'start',
cursor:'default',
data: [],
symbolOffset: ['0', '50%'],
symbol : 'diamond',
symbolSize: [20, 10],
itemStyle: {
normal: {
color: function (params) {
return _this.colors[params.dataIndex];
}
}
},
label: {show: false}
}
]
};
},
// 设置数据列表
setDataList(dataList) {
this.dataList = dataList;
},
/**
* @description 初始化的方法
* @name init
* @return {*} 无
*/
init() {
// 更新数据
this.update(this.data);
},
/**
* @description 刷新图表
* @return {*} 无
*/
refresh() {
if (this.myEchart) {
this.update(this.dataList);
}
},
/**
* @description 设置图表的数据
* @name getChartData
* @param {object} data 参数
* @return {*} 无
*/
update(data) {
// 先判断数据是否存在
if (!Array.isArray(data)) {
return false;
}
// 设置数据列表
this.setDataList(data);
// 如果不存在echarts
if (!this.myEchart) {
// 图表对象
this.myEchart = window.echarts.init(this.$refs.jsEchart);
// 绑定resize 事件
this.bindResizeEvent();
}
// 设置默认参数
this.setDefaultOptions();
// 方向排序
const _data = data;
// 更新数据
this.updateData(_data);
// 清空图表
this.myEchart.clear();
// 生成图表
this.myEchart.setOption(this.options);
},
// 更新数据对象
updateData(data) {
// 处理series数据
const series = [];
// 处理x轴
const xAxis = [];
// 设置y轴为10的倍数
const _num = 10;
data.forEach(item => {
xAxis.push(item.name);
series.push(item.value);
});
// 找到最大值
const max = Math.max.apply(null, series);
// 设置y轴为10的倍数
this.options.yAxis[0].max = max > _num ? Math.ceil(max / _num) * _num : _num;
this.options.xAxis[0].data = xAxis;
this.options.series.forEach(item => {
item.data = series;
});
},
// resize 事件处理函数
resizeHandler() {
if (this.myEchart) {
this.myEchart.resize();
}
},
/**
* @description 绑定resize 事件
* @name init
* @return {*} 无
*/
bindResizeEvent() {
// 绑定resize事件
window.eventHandler.on(window, 'resize', this.resizeHandler);
},
// 取消事件绑定
unbindResizeEvent() {
// 取消绑定resize事件
window.eventHandler.off(window, 'resize', this.resizeHandler);
},
/**
* @description 销毁图表
* @name destroyedChart
* @return {*} 无
*/
destroyedChart() {
// 如果存在echarts
if (this.myEchart) {
// 销毁实例,销毁后实例无法再被使用。
this.myEchart.dispose();
this.myEchart = null;
// 取消事件绑定
this.unbindResizeEvent();
}
}
}
};
图二
- 特点
- 饼图带symbol
- 边框
- 间距
- 重点
- 间距是series写的间距需要固定比较不容易想到使用total
- label展示(分左右两边)
- label上带图标
/**
* @version 1.0.1
* @author yfeng
* @createTime:2021-08-01,
* @updateTime:2021-08-01
* @copyright thunisoft fd
*/
// 事件处理函数
export default {
props: {
// 需要传递的数据
data: {
type: Array,
default() {
return [{
name:'A',
value:0
}, {
name:'B',
value:20
}, {
name:'C',
value:20
}, {
name:'D',
value:20
}, {
name:'E',
value:20
}];
}
}
},
data() {
return {
// echarts对象
myEchart: null,
// 数据列表
dataList: [],
// echart的options
options: {}
};
},
// 创建元素
mounted() {
this.init();
},
// 销毁
destroyed() {
// 销毁图表
this.destroyedChart();
},
methods: {
// 设置默认参数
setDefaultOptions() {
// 默认的参数
this.options = {
title:[{
show:false,
text:'10',
x: '50%',
y: '33%',
textAlign: 'center',
textStyle: {
fontSize: '46',
fontWeight:'bold',
color: '#36e7ff',
textAlign: 'center',
textShadowBlur:10,
textShadowColor:'rgba(233,236,254,0.35)'
}
}, {
show:false,
text:'总人数',
x: '50%',
y: '47%',
textAlign: 'center',
textStyle: {
fontSize: '24',
fontWeight:'bold',
color: '#d5f9fc',
textAlign: 'center'
}
}],
tooltip: {
show: true,
textStyle: {color: '#fff'},
padding: [10, 10]
},
series: [
{
type: 'pie',
radius: ['70', '82'],
center: ['50%', '50%'],
hoverAnimation: false,
startAngle:0,
z: 10,
label:{
show:true,
align: 'left',
rich: {
txt: {
color: '#fff',
width:55,
padding: [10, 0, 0, -40]
},
txt1: {
color: '#fff',
width:55,
padding: [10, 0, 0, -40]
},
san: {
width:40,
height:32,
padding: [20, 0, 0, -85],
align: 'left',
backgroundColor:{image:''}
},
san1: {
width:40,
height:32,
padding: [20, 0, 0, -115],
align: 'left',
backgroundColor:{image:''}
}
}
},
labelLine: {
show: true,
length:20,
length2:30,
lineStyle: {
color: '#228cd1',
width: 2
}
},
data: [{
itemStyle: {
normal: {
borderWidth:2,
borderColor: 'rgb(255,225,143)',
shadowBlur: 20,
shadowColor:'rgba(255,225,143,0.3)',
color: 'rgba(255,225,143,0.7)'
}
},
name: 'A',
value:50
}, {
value: 2,
name: '',
labelLine:{show:false},
emphasis:{labelLine:{show:false}},
itemStyle: {normal: {color: 'transparent'}}
}, {
itemStyle: {
normal: {
borderWidth:2,
borderColor: 'rgb(11,165,234)',
shadowBlur: 20,
shadowColor:'rgba(11,165,234,0.3)',
color: 'rgba(11,165,234,0.7)'
}
},
name: 'B',
value:50
}, {
value: 2,
name: '',
labelLine:{show:false},
emphasis:{labelLine:{show:false}},
itemStyle: {normal: {color: 'transparent'}}
}, {
itemStyle: {
normal: {
borderWidth:2,
borderColor: 'rgb(52,236,255)',
shadowBlur: 20,
shadowColor:'rgba(52,236,255,0.3)',
color: 'rgba(52,236,255,0.7)'
}
},
name: 'C',
value:50
}, {
value: 2,
name: '',
labelLine:{show:false},
emphasis:{labelLine:{show:false}},
itemStyle: {normal: {color: 'transparent'}}
}, {
itemStyle: {
normal: {
borderWidth:2,
borderColor: 'rgb(0,252,155)',
shadowBlur: 20,
shadowColor:'rgba(0,252,155,0.3)',
color: 'rgba(0,252,155,0.7)'
}
},
name: 'D',
value:50
}, {
value: 2,
name: '',
labelLine:{show:false},
emphasis:{labelLine:{show:false}},
itemStyle: {normal: {color: 'transparent'}}
}, {
itemStyle: {
normal: {
borderWidth:2,
borderColor: 'rgb(244,115,195)',
shadowBlur: 20,
shadowColor:'rgba(244,115,195,0.3)',
color: 'rgba(244,115,195,0.7)'
}
},
name: 'E',
value:50
}, {
value: 20,
name: '',
labelLine:{show:false},
emphasis:{labelLine:{show:false}},
itemStyle: {normal: {color: 'transparent'}}
}]
}
]
};
},
// 设置数据列表
setDataList(dataList) {
this.dataList = dataList;
},
/**
* @description 初始化的方法
* @name init
* @return {*} 无
*/
init() {
// 更新数据
this.update(this.data);
},
/**
* @description 刷新图表
* @return {*} 无
*/
refresh() {
if (this.myEchart) {
this.update(this.dataList);
}
},
/**
* @description 设置图表的数据
* @name getChartData
* @param {object} data 参数
* @return {*} 无
*/
update(data) {
// 先判断数据是否存在
if (!Array.isArray(data)) {
return false;
}
// 设置数据列表
this.setDataList(data);
// 如果不存在echarts
if (!this.myEchart) {
// 图表对象
this.myEchart = window.echarts.init(this.$refs.jsEchart);
// 绑定resize 事件
this.bindResizeEvent();
}
// 设置默认参数
this.setDefaultOptions();
// 方向排序
const _data = data;
// 更新数据
this.updateData(_data);
// 清空图表
this.myEchart.clear();
// 生成图表
this.myEchart.setOption(this.options);
},
// 更新数据对象
updateData(data) {
// 获取数据的长度
const length = data.length;
// 因为有间距所以series是两份
const _num = 2;
// 总数
let total = 0;
// 取需要长度的series
this.options.series[0].data.splice(length * _num);
// 正常的数据处理并获取total
this.options.series[0].data.forEach((item, index) => {
if (index % _num === 0) {
item.name = data[index / _num].name;
item.value = data[index / _num].value;
total += parseFloat(item.value);
}
});
// 不能放在上面写是因为需要total
this.options.series[0].data.forEach((item, index) => {
if (index % _num !== 0) {
// 一个随机的值
const _random = 50;
item.value = total / _random;
}
});
this.options.tooltip.formatter = function (params) {
const _percent = 100;
let text = `<div>${params.marker} ${params.data.name}:${params.data.value}人`;
text += `<span style="padding-left: 18px">${Math.round((parseFloat(params.data.value) / total * _percent) * _percent) / _percent}%</span></div>`;
if (params.data.name) {
return text;
}
};
this.options.series[0].label.formatter = function (params) {
// 当前值加上之前的值
let current = 0;
if (params.dataIndex % _num === 0) {
data.forEach((item, index) => {
// 当前值一半加上前面的值是否大于50%(判断label朝向)
if (index <= (params.dataIndex / _num)) {
if (index === params.dataIndex / _num) {
current += Number(item.value) / _num;
} else {
current += Number(item.value);
}
}
});
}
if (params.data.name) {
// 因为是从4/1处开始的所以是0.25
// 若当前值一半加上前面的值的占比大于0.5三角形朝右,相反朝左
if (current / total >= 0.25 && current / total < 0.75) {
return `{txt1| ${params.data.value}}{san1|}`;
}
return `{txt| ${params.data.value}}{san|}`;
}
};
},
// resize 事件处理函数
resizeHandler() {
if (this.myEchart) {
this.myEchart.resize();
}
},
/**
* @description 绑定resize 事件
* @name init
* @return {*} 无
*/
bindResizeEvent() {
// 绑定resize事件
window.eventHandler.on(window, 'resize', this.resizeHandler);
},
// 取消事件绑定
unbindResizeEvent() {
// 取消绑定resize事件
window.eventHandler.off(window, 'resize', this.resizeHandler);
},
/**
* @description 销毁图表
* @name destroyedChart
* @return {*} 无
*/
destroyedChart() {
// 如果存在echarts
if (this.myEchart) {
// 销毁实例,销毁后实例无法再被使用。
this.myEchart.dispose();
this.myEchart = null;
// 取消事件绑定
this.unbindResizeEvent();
}
}
}
};
- echarts官网上网友提供了各种各样的图,如果你做了非常炫酷的可以往上传哟www.makeapie.com/explore.htm…
- 对于拿到一个自己没有见过的图形的时候我的做法
- 先在上面网址找一个相似的图像
- 在根据自己需要去调整,调整的时候参照API(echarts.apache.org/zh/option.h…
- 如果echarts实在不能解决,就用css+js解决吧
- echarts版本不同,有些配置项层级可能不同
- 由于代码太多,字数超过限制,所以下面链接还有两个图
- juejin.cn/post/699801…
- 之前还遇到过echarts中series中的lable使用rich并且改变position文字出现黑边的问题详细内容参照(juejin.cn/post/684490…