飙血推荐
  • HTML教程
  • MySQL教程
  • JavaScript基础教程
  • php入门教程
  • JavaScript正则表达式运用
  • Excel函数教程
  • UEditor使用文档
  • AngularJS教程
  • ThinkPHP5.0教程

echarts中饼状图数据太多进行翻页

时间:2021-12-03  作者:IwishIcould  

echarts饼状图数据太多

echarts 饼状图内容太多怎么处理

有些时候,我们饼状图中echarts的数据可能会很多。
这个时候展示肯定会密密麻麻的。导致显示很凌乱
我们需要\'翻页\'类似表格展示下一页的数据

在legend中下需要配置属性 type: \'scroll\',表示滚动
数据太多可以滚动的形式进展示
如下:
legend: {
	type: \'scroll\',
}

自定义分页箭头

但是我们发现这个分页箭头不好看。
所以我们需要优化这个分页的箭头
通过官网的描述信息我们配置如下这只
这里设置箭头的路径
var option = {
	legend: {
		type: \'scroll\', 滚动
		orient: \'vertical\', 垂直方向滚动
		pageIcons: {
		 	vertical: [
		 		\'path://域名 域名-域名 域名-域名 域名-域名 域名 0 域名 域名 域名 域名 域名 域名 0L512 域名 域名 域名 域名 域名 域名 0 域名-域名 域名-域名 0-域名 域名 域名 域名 域名 域名 域名\',
				\'path://域名 域名 域名 域名-域名-域名-域名-域名 0-域名 域名-域名 域名-域名 域名 0L512 域名-域名-域名 域名-域名 域名 0 域名 域名 域名 域名 0 域名-域名 域名 域名 域名 域名 域名 域名\',
			],
		},
		pageButtonPosition: \'end\', // 翻页的位置。\'start\':控制块在左或上,end控制块在右或下。
		pageIconColor: \'#29bca8\', // 可以点击的翻页按钮颜色
		pageIconInactiveColor: \'#7f7f7f\', // 禁用的按钮颜色
		pageIconSize: 14, //这当然就是按钮的大小
	}
}

有的小伙伴会好奇
path的值怎么来的,我是从svg中获取的,

如何在iconfont中获取图标的svg代码

pageIcons 的值哪些?

第1种:svg的代码,就是我刚刚使用的

第2种:URL为图片链接例如:\'image://http://域名/a/域名\'

第3种:URL为dataURI 例如:
\'image://
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACH5BAkAABAALAAAAAAQABAAAAVVICSOZGlCQAosJ6mu7fiyZeKqNKToQGDsM8hBADgUXoGAiqhSvp5QAnQKGIgUh
wFUYLCVDFCrKUE1lBavAViFIDlTImbKC5Gm2hB0SlBCBMQiB0UjIQA7\'

定义legend的显示内容样式的设置

在legend下有一个formatter属性
我们可以通过 formatter 来自定义文字
formatter: function(name) {
	let showNum
	let percentage
	for (var i = 0; i < 域名th; i++) {
		if (listSummary[i].name == name) {
			showNum = listSummary[i].value
			if (lejibaoxiuTotals) { //lejibaoxiuTotals可能为0
				// 计算百分比
				percentage =((listSummary[i].value /lejibaoxiuTotals) *100).toFixed(2) + \'%\'
			} else {
				percentage = \'\'
			}
		}
	}
	return `{name| ${ 域名th > 5 ? 域名e(0, 5) + \'...\' : name}}
	| {val| ${percentage}}  {numNum| ${showNum}}`
},

通过富文本来控制样式
textStyle: {
	fontSize: 13, //字体的大小
	color: \'#D9D9D9\',
	rich: {
		//设置name属性的样式(显示的:华为x),这里与 return中的name保持一致
		name: {
			color: \'#595959\',
			width: 77, //宽度
			padding: [0, 0, 0, 0], //间距表示 上右下左
		},
		//设置val(百分比)属性的样式,这里与 return中的val保持一致
		val: {
			width: 50,//宽度
			color: \'#8c8c8c\', 、
			padding: [0, 10, 0, 6], //间距表示 上右下左
		},
		//设置numNum(数量)属性的样式,这里与 return中的numNum保持一致
		numNum: {
			color: \'#8c8c8c\',
		},
	},
},

这样就好看一些了

最终的代码

<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8">
		<meta http-equiv="X-UA-Compatible" content="IE=edge">
		<meta name="viewport" content="width=device-width, initial-scale=1.0">
		<title>Document</title>
		<script src="https://域名/echarts/4.3.0/域名"></script>
	</head>
	<body>
<div  style="width: 600px;height: 500px;background-color: pink;"></div>
<script>
	var myChart  = 域名(域名ySelector(\'div\'))
	let lejibaoxiuTotals=140;
	let listSummary=[
		{name:\'华为1\',value:10},
		{name:\'华为2\',value:10},
		{name:\'华为3\',value:10},
		{name:\'华为4\',value:10},
		{name:\'华为5\',value:10},
		{name:\'华为6\',value:10},
		{name:\'华为7\',value:10},
		{name:\'华为8\',value:10},
		{name:\'华为9\',value:10},
		{name:\'华为10\',value:10},
		{name:\'华为12\',value:10},
		{name:\'华1为13\',value:10},
		{name:\'012华3为\',value:10},
		{name:\'华1为2\',value:10},
		
		
	]
	var option = {
		tooltip: {
			trigger: \'item\',
		},
		legend: {
			type: \'scroll\',
			orient: \'vertical\',
			top: \'center\',
			bottom: 40,
			right: 40,
			icon: \'circle\',
			itemGap: 18,
			itemWidth: 8,
			itemHeight: 8,
			pageButtonItemGap: 5,
			textStyle: {
				fontSize: 13,
				color: \'#D9D9D9\',
				rich: {
					name: {
						color: \'#595959\',
						width: 77,
						padding: [0, 0, 0, 0],
					},
					val: {
						width: 50,
						color: \'#8c8c8c\',
						padding: [0, 10, 0, 6],
					},
					numNum: {
						color: \'#8c8c8c\',
					},
				},
			},
			// 控制legend的间距
			padding: [10, 0, 20, 20],
			// 这里设置箭头的路径
			pageIcons: {
				vertical: [
					\'path://域名 域名-域名 域名-域名 域名-域名 域名 0 域名 域名 域名 域名 域名 域名 0L512 域名 域名 域名 域名 域名 域名 0 域名-域名 域名-域名 0-域名 域名 域名 域名 域名 域名 域名\',
					\'path://域名 域名 域名 域名-域名-域名-域名-域名 0-域名 域名-域名 域名-域名 域名 0L512 域名-域名-域名 域名-域名 域名 0 域名 域名 域名 域名 0 域名-域名 域名 域名 域名 域名 域名 域名\',
				],
			},
			pageButtonPosition: \'end\', // 翻页的位置。\'start\':控制块在左或上,end控制块在右或下。
			pageIconColor: \'#29bca8\', // 可以点击的翻页按钮颜色
			pageIconInactiveColor: \'#7f7f7f\', // 禁用的按钮颜色
			pageIconSize: 14, //这当然就是按钮的大小
			
			formatter: function(name) {
				let showNum
				let percentage
				for (var i = 0; i < 域名th; i++) {
					if (listSummary[i].name == name) {
						showNum = listSummary[i].value
						if (lejibaoxiuTotals) {
							// 计算百分比
							percentage =((listSummary[i].value /lejibaoxiuTotals) *100).toFixed(2) + \'%\'
						} else {
							percentage = \'\'
						}
					}
				}
				return `{name| ${域名th > 5 ? 域名e(0, 5) + \'...\' : name}} | {val| ${percentage}}  {numNum| ${showNum}}`
			},
		},

		series: [{
			type: \'pie\',
			// 饼粗的大小
			radius: [\'44%\', \'60%\'],
			// 图形展示的位置
			center: [\'30%\', \'center\'],
			avoidLabelOverlap: false,
			itemStyle: {
				borderRadius: 0,
				borderColor: \'#fff\',
				borderWidth: 2,
			},
			label: {
				show: false,
				position: \'center\',
			},
			// emphasis 不展示中间的文字
			labelLine: {
				show: false,
			},

			data: listSummary, //[{name:\'xx\',value:\'x\'}]
		}, ],
		title: {
			text: lejibaoxiuTotals ? lejibaoxiuTotals : \'\', //展示的总数据
			left: \'27%\',
			top: \'47%\',
			textStyle: {
				color: \'#031f2d\',
				fontSize: 20,
				align: \'center\',
			},
		},
	}
	// 使用刚指定的配置项和数据显示图表。
	域名ption(option)
</script>
	</body>
</html>

尾声

如果你觉得我写的还不错的话
关注我或者给我点赞打赏
这是我写下去的动力

标签:编程
湘ICP备14001474号-3  投诉建议:234161800@qq.com   部分内容来源于网络,如有侵权,请联系删除。