ECharts 是一个由百度开源的强大、灵活的 JavaScript 图表库,用于在 Web 页面上创建各种类型的数据可视化图表。它具有丰富的图表类型、强大的配置选项和良好的跨平台兼容性,广泛应用于数据分析、业务报表、仪表盘等场景。
ECharts 的安装和引入非常简单,可以通过以下几种方式来使用:
最简单的方式是通过 CDN 引入 ECharts 的脚本文件。在 HTML 文件中添加如下代码即可:
DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>ECharts 示例title>
<script src="https://cdn.jsdelivr.net/npm/echarts/dist/echarts.min.js">script>
head>
<body>
<div id="main" style="width: 600px;height:400px;">div>
<script type="text/javascript">
// 在此处添加 ECharts 使用代码
script>
body>
html>
如果你使用的是前端开发工具如 webpack、vite 等,可以通过 npm 安装 ECharts:
npm install echarts --save
安装后在项目中引入:
import * as echarts from 'echarts';
接下来,我们通过一个简单的实例来展示如何使用 ECharts 创建图表。以下是一个基本的折线图示例:
在 HTML 中创建一个用于渲染图表的容器:
<div id="main" style="width: 600px;height:400px;">div>
在容器中初始化 ECharts 实例,并设置图表选项:
var chartDom = document.getElementById('main');
var myChart = echarts.init(chartDom);
var option = {
title: {
text: '示例折线图'
},
tooltip: {
trigger: 'axis'
},
xAxis: {
type: 'category',
data: ['周一', '周二', '周三', '周四', '周五', '周六', '周日']
},
yAxis: {
type: 'value'
},
series: [{
data: [820, 932, 901, 934, 1290, 1330, 1320],
type: 'line'
}]
};
myChart.setOption(option);
执行上述代码后,你将会在页面上看到一个简单的折线图。
ECharts 支持多种图表类型,以下是几种常见的图表及其配置示例:
var option = {
title: {
text: '销量柱状图'
},
tooltip: {},
xAxis: {
data: ["衬衫", "羊毛衫", "雪纺衫", "裤子", "高跟鞋", "袜子"]
},
yAxis: {},
series: [{
name: '销量',
type: 'bar',
data: [5, 20, 36, 10, 10, 20]
}]
};
var option = {
title: {
text: '某站点用户访问来源',
subtext: '纯属虚构',
left: 'center'
},
tooltip: {
trigger: 'item'
},
legend: {
orient: 'vertical',
left: 'left'
},
series: [
{
name: '访问来源',
type: 'pie',
radius: '50%',
data: [
{value: 1048, name: '搜索引擎'},
{value: 735, name: '直接访问'},
{value: 580, name: '邮件营销'},
{value: 484, name: '联盟广告'},
{value: 300, name: '视频广告'}
],
emphasis: {
itemStyle: {
shadowBlur: 10,
shadowOffsetX: 0,
shadowColor: 'rgba(0, 0, 0, 0.5)'
}
}
}
]
};
var option = {
title: {
text: '中国地图示例',
left: 'center'
},
tooltip: {
trigger: 'item'
},
visualMap: {
min: 0,
max: 1000,
left: 'left',
top: 'bottom',
text: ['高','低'],
calculable: true
},
series: [
{
name: '数据',
type: 'map',
mapType: 'china',
roam: false,
label: {
show: true
},
data:[
{name: '北京', value: Math.round(Math.random()*1000)},
{name: '上海', value: Math.round(Math.random()*1000)},
// 更多省份数据
]
}
]
};
ECharts 支持响应式设计,可以根据容器大小自动调整图表尺寸。你只需要确保在容器尺寸改变后调用 myChart.resize()
方法即可:
window.addEventListener('resize', function() {
myChart.resize();
});
ECharts 提供多种内置主题,并且支持自定义主题。你可以通过配置项来自定义图表的样式,如颜色、字体等。
ECharts 支持动态更新图表数据,你可以使用 setOption
方法来更新数据,而不必重新创建图表:
myChart.setOption({
series: [{
data: [120, 200, 150, 80, 70, 110, 130]
}]
});
ECharts 是一个功能强大的数据可视化工具,它提供了丰富的图表类型和灵活的配置选项,适合各种场景下的数据展示需求。