echarts中的饼图
时间: 2024-12-29 17:15:40 浏览: 20
### ECharts 饼图 使用方法 示例 教程
#### 创建基本饼图
要使用ECharts创建一个简单的饼图,首先需要引入ECharts库并初始化图表容器。下面是一个完整的HTML文件示例:
```html
<!DOCTYPE html>
<html style="height: 100%">
<head>
<!-- 引入 echarts.js -->
<script src="https://cdn.jsdelivr.net/npm/echarts/dist/echarts.min.js"></script>
</head>
<body style="height: 100%; margin: 0">
<!-- 为ECharts准备一个具备大小(宽高)的DOM -->
<div id="main" style="height: 100%"></div>
<script type="text/javascript">
// 基于准备好的dom,初始化echarts实例
var myChart = echarts.init(document.getElementById('main'));
// 指定图表的配置项和数据
var option = {
title : {
text: '某站点用户访问来源',
subtext: '纯属虚构',
left: 'center'
},
tooltip : {
trigger: 'item'
},
legend: {
orient: 'vertical',
left: 'left',
},
series : [
{
name: '访问来源',
type: 'pie',
radius : '55%',
center: ['50%', '60%'],
data:[
{value:335, name:'直接访问'},
{value:310, name:'邮件营销'},
{value:234, name:'联盟广告'},
{value:135, name:'视频广告'},
{value:1548, name:'搜索引擎'}
],
itemStyle: {
emphasis: {
shadowBlur: 10,
shadowOffsetX: 0,
shadowColor: 'rgba(0, 0, 0, 0.5)'
}
}
}
]
};
// 使用刚指定的配置项和数据显示图表。
myChart.setOption(option);
</script>
</body>
</html>
```
此代码片段展示了如何设置标题、提示框、图例以及系列中的具体数据[^1]。
#### 自定义图标
对于希望给每个扇区添加特定图标的场景,可以通过`markPoint`属性实现更复杂的视觉效果。这里给出一段简化版的例子来说明这一过程:
```javascript
series: [{
...
markPoint: {
symbolSize: function (v) {
return v * 10;
},
data: [
{name: "足球", value: 90, xAxis: '50%', yAxis: '70%', symbol: 'path://M...'}, // SVG路径字符串代表自定义形状
{name: "篮球", value: 80, ...},
...
]
}
}]
```
请注意,在实际应用中可能还需要调整坐标位置和其他样式细节以适应页面布局需求[^2]。
#### 定制化图例外观
当涉及到修改默认图例外观时,则可以利用`legend`对象下的多个参数来进行定制。例如改变文字颜色、间距或是方向等特性均能通过相应字段完成设定。此外还支持动态更新图例内容的方法,如下所示:
```javascript
init() {
this.option.legend[0].data = legendName.slice(0, 5); // 设置左侧前五个项目
this.option.legend[1].data = legendName.slice(-5); // 设置右侧最后五个项目
}
```
同时为了增强用户体验,还可以借助`formatter`函数向图例条目追加额外信息,比如显示所占比例等等[^3]。
阅读全文