多功能echarts柱状图

数据结构:

data = [
    {
        name: '类别1',
        value: 15,
        children: [
            {
                name: '项目1-1',
                value: 87,
                value2: 3.3,
            },
            {
                name: '项目1-2',
                value: 80,
                value2: 2.6,
            },
            {
                name: '项目1-3',
                value: 79,
                value2: 3.8,
            },
        ]
    },
    {
        name: '类别2',
        value: 15,
        children: [
            {
                name: '项目2-1',
                value: 70,
                value2: 1.5,
            },
            {
                name: '项目2-2',
                value: 60,
                value2: 2.1,
            },
            {
                name: '项目2-3',
                value: 65,
                value2: 1.6,
            },
        ]
    },
    {
        name: '类别3',
        value: 25,
        children: [
            {
                name: '项目3-1',
                value: 80,
                value2: 3.1,
            },
            {
                name: '项目3-2',
                value: 68,
                value2: 2.5,
            },
        ]
    },
    {
        name: '类别4',
        value: 25,
        children: [
            {
                name: '项目4-1',
                value: 67,
                value2: 2.7,
            },
            {
                name: '项目4-2',
                value: 70,
                value2: 1.8,
            },
            {
                name: '项目4-3',
                value: 77,
                value2: 2.3,
            },
        ]
    },
    {
        name: '类别5',
        value: 20,
        children: [
            {
                name: '项目5-1',
                value: 50,
                value2: 9.1,
            },
        ]
    },
];
options:
initChart() {
	let myChart = this.$echarts.init(this.$refs.echarts);
	let corlor = ['#4594F9','#7BFBE9','#7D7446','#5E76DE','#4FE4A2'];
	let data = [];
	let nameList = [];
	let markPointData = [];
	let imgList = [
		'image://',
		"image://",
		"image://",
		"image://",
		"image://",
	];
	let num = 0;
	this.factorAnalysisList.forEach((item,i) => {
		item.children.forEach(k => {
			data.push({
				name: k.name,
				name2: item.name,
				valueAll: item.value || 0,
				value: (k.value2 * 100).toFixed(2) || 0,
				value2: k.value || 0,
				itemStyle: {
					color: corlor[i]
				}
			});
			nameList.push(k.name)
		});
		let size = 0;
		num += item.children.length;
		let leftNum = num - (item.children.length - 1) / 2 - 1;
		if (item.children.length % 2 !== 1) {
			size = -40
		}
		markPointData.push(
			{
				coord: [leftNum,100],
				type: 'max',
				data: item,
				symbol: imgList[i],
				symbolSize: [54*item.children.length, 20],
				symbolOffset: [size, -10],
				label: {
					show: true,
					distance: 80,
					formatter: () => {
						return '{name|' + item.name + '}' + '\n' + '{name2|' + item.value + '分}'
					},
					rich: {
						name: {
							align: 'center',
							color: corlor[i],
							fontWeight: 'bold',
							marginBottom: '12px',
							fontSize: '12px'
						},
						name2: {
							align: 'center',
							color: '#fff',
							padding: [6,0,50,0],
						},
					}
				}
			},
		);
	});
	let option = {
		tooltip: {
			// trigger: 'axis',
			backgroundColor: 'rgba(7,20,54,0.8)',
			textStyle: {
				color: '#fff',
				lineHeight: 100,
				fontSize: 13,
			},
			borderColor: '#2FD5FF',
			formatter: (params) => {
				let html = "";
				if (params.seriesType === 'bar') { //
					html += `${params.data.name}</br>`;
					html += `<span style="display:inline-block;margin-right:4px;border-radius:10px;width:10px;height:10px;background-color:#F1A305"></span> 得分率:${params.data.value || 0}% </br>`;
					html += `<span style="display:inline-block;margin-right:4px;border-radius:10px;width:10px;height:10px;background-color:#4BF804"></span> 得分:${params.data.value2 || 0}分</br>`;
					return `<div style="line-height:22px">${html}</div>`;
				} else {
					if (params.data.data) {
						html += `${params.data.data.name}</br>`;
						html += `<span style="display:inline-block;margin-right:4px;border-radius:10px;width:10px;height:10px;background-color:#BFC413"></span> 分值:${params.data.data.fullMark || 0}分</br>`;
						html += `<span style="display:inline-block;margin-right:4px;border-radius:10px;width:10px;height:10px;background-color:#206366"></span> 得分:${params.data.data.grade || 0}分</br>`;
						html += `<span style="display:inline-block;margin-right:4px;border-radius:10px;width:10px;height:10px;background-color:#2391FF"></span> 得分率:${Number((params.data.data.gradeRate * 100).toFixed(2))}%</br>`;
						return `<div style="line-height:22px">${html}</div>`;
					}
				}
			},
			axisPointer: {
				type: 'shadow'
			}
		},
		grid: {
			top: '15%',
			left: '3%',
			right: '3%',
			bottom: '0%',
			containLabel: true
		},
		calculable: true,
		xAxis: [
			{
				type: 'category',
				data: nameList,
				axisLabel: {
					color: '#fff',
					fontSize: 10,
					width: 50,
					interval: 0,
					overflow: 'break',
					lineHeight: 15,
					// rotate: 40,
					margin: 8,
				},
				axisTick: {
					show: false
				},
			}
		],
		yAxis: [
			{
				max: 100,
				splitNumber: 10,
				name: '得分率',
				type: 'value',
				splitLine: {
					show: false,
				},
				// nameGap: 20,
				nameTextStyle: {
					color: '#fff',
					fontSize: 12,
					align: 'right'
				},
				axisLabel: {
					color: '#fff',
					fontSize: 10,
					// interval: 0,
					margin: 10,
					formatter: (params) => {
						return params + '%'
					},
				},
			}
		],
		series: [
			{
				name: '',
				type: 'bar',
				barWidth: '12', // 统计条宽度
				data: data,
				markPoint: {
					emphasis: {
						disabled: false,
					},
					data: markPointData
				},
				label: {
					show: true,
					precision: 1,
					position: 'top',
					color: '#fff',
					fontSize: 12,
					distance: 4,
					formatter: (params) => {
						return params.data.value2
					},
				},
				markLine: {
					symbol: 'none',
					data: [
						{
							yAxis: 60,
							name: '合格',
							lineStyle: {
								color: '#D42B31',
							},
							label: {
								formatter: '合格',
								color: '#fff',
							}
						},
						{
							yAxis: 70,
							name: '一般',
							lineStyle: {
								color: '#E9AB34',
							},
							label: {
								formatter: '一般',
								color: '#fff',
							}
						},
						{
							yAxis: 80,
							name: '良好',
							lineStyle: {
								color: '#378494',
							},
							label: {
								formatter: '良好',
								color: '#fff',
							}
						},
						{
							yAxis: 90,
							name: '优秀',
							lineStyle: {
								color: '#61F941',
							},
							label: {
								formatter: '优秀',
								color: '#fff',
							}
						},
					]
				}
			}
		]
	};
	myChart.clear();
	myChart.setOption(option, true);
},

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值