ECharts可视化基础——柱状图
ECharts可视化基础2ECharts可视化基础3ECharts可视化基础4
1.ECharts可视化步骤
ECharts可视化分为5步,分别为:
①步骤1:引入echarts.js文件
需在head标签内引入js文件,我们需要通过script标签中的scr属性来给外部脚本文件规定一个路径。
②准备容器
我们需要准备一个呈现图表的盒子,通常我们是在div标签内规定一个区域来呈现图表。
③初始化ECharts实例对象
我们在script标签内,通过echarts.init的方法实例化echarts对象,使用init中的document.getElementById的方法将实例化的对象呈现在步骤二规定的容器内,上述方法需要div标签的id。还可以用document.querySelector获取页面中的div元素,该方法不需要有div标签的id值。用var定义一个变量名来命名此实例对象。
④准备配置项
Echarts呈现的效果主要由该部分决定。用var定义一个变量名来命名此配置项。
通过xAxis:{type:,data:}绘制横坐标,type详情可见https://echarts.apache.org/zh/option.html#xAxis.type,通过data传递x轴数据。
通过yAxis:{type,}绘制横坐标,type通xAxis,data通过series传递。
通过series:[]传递图形数据,通常一个对象为一组数据,如:{name:,type:,data:},name为该组数据名称,type为图类型,data为y轴数据。
⑤将配置项设置给echarts实例对象
通过setOption方法将刚才配置项设置给实例对象。
2.基础柱状图的绘制。
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>ECharts</title>
<!-- 引入 echarts.js -->
<script src="echarts.min.js"></script>
</head>
<body>
<!-- 为ECharts准备一个具备大小(宽高)的Dom -->
<div id="main" style="width: 600px;height:400px;"></div>
<script type="text/javascript">
// 基于准备好的dom,初始化echarts实例
var myChart = echarts.init(document.getElementById('main'));
// 指定图表的配置项和数据
var option = {
title:{
text:'成绩显示',
textStyle:{
color:'orange'
},
borderWidth:5,
borderColor:'orange',
borderRadius:20,
left:150
},
tooltip: {
trigger:'item',
triggerOn:'click',
// formatter:'{b}:{c}',
formatter:function(arg){
console.log(arg)
return arg.name + '的' + arg.data + '分数是:' + arg.data
}
},
legend: {
data:['语文','数学']
},
xAxis: {
data: ["张三","李四","王五","闰土","小明","茅台","二妞","大强"]
},
yAxis: {},
series: [{
name: '语文',
type: 'bar',
data: [88,92,63,77,94,80,72,86],
color:'red',
}],
};
// 使用刚指定的配置项和数据显示图表。
myChart.setOption(option);
</script>
</body>
</html>
3.柱状图的标记与显示。
根据柱状图,标记出语文成绩的最高值和最低值,并标记出平均值线。
在series中使用markPoint标记点,其代码格式可在官网配置项手册中搜索‘series-line.markPoint.data. type’,使用markLine标记线,其代码格式可在官网配置项手册中搜索‘series-line.markLine.data.0. type’。
在该柱状图中显示每个柱子的数值,调整柱宽度为原柱的50%,尝试将竖柱状图调整为横柱状图。
在series中使用Label显示数值,在配置项手册中,可通过‘series- xxx. label’查询某图label配置项,柱状图详情见‘series-bar. Label’。
柱宽度通过barWidth设置,可点击网址后点击右边的试一试,‘https://echarts.apache.org/zh/option.html#series-bar.barWidth’
柱状图方向调整通过对xAxis和yAxis数据的调整实现。
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>ECharts</title>
<!-- 引入 echarts.js -->
<script src="echarts.min.js"></script>
</head>
<body>
<!-- 为ECharts准备一个具备大小(宽高)的Dom -->
<div id="main" style="width: 600px;height:400px;"></div>
<script type="text/javascript">
// 基于准备好的dom,初始化echarts实例
var myChart = echarts.init(document.getElementById('main'));
// 指定图表的配置项和数据
var option = {
title:{
text:'成绩显示',
textStyle:{
color:'orange'
},
borderWidth:5,
borderColor:'orange',
borderRadius:20,
left:150
},
toolbox: {
show: true,
feature: {
dataZoom: {
yAxisIndex: "none"
},
dataView: {
readOnly: false
},
magicType: {
type: ["line", "bar"]
},
restore: {},
saveAsImage: {}
}
},
legend: {
type: "scroll"
},
tooltip: {
trigger:'item',
triggerOn:'mousemove',
// formatter:'{b}:{c}',
formatter:function(arg){
console.log(arg)
return arg.name + '的分数是:' + arg.data
}
},
legend: {
data:['语文']
},
yAxis: {
data: ["张三","李四","王五","闰土","小明","茅台","二妞","大强"]
},
xAxis: {},
series: [{
name: '语文',
type: 'bar',
data: [88,92,63,77,94,80,72,86],
color:'blue',
markPoint:{
data:[
{
type:'max',name:'最大值'
},
{
type:'min',name:'最小值'
}
]
},
markLine:{
data:[
{
type:'average',name:'平均值'
}
]
},
label:{
show:true,
rotate:60
},
barWidth: "50%"
}],
};
// 使用刚指定的配置项和数据显示图表。
myChart.setOption(option);
</script>
</body>
</html>
4.通用配置的设置。
通用配置指的是其他图形都含有的配置,如标题title、提示框tooltip、工具栏toolbox、图例legend。
根据配置手册中title的属性,在柱状图的基础上将标题设置为‘成绩展示’,设置字体颜色为‘orange’,尝试更改字体风格等设置,设置合适的边框宽度,颜色和边框圆角半径,调整标题位置,并将echarts配置项手册网址设置为主标题的文本超链接。
请根据配置手册中tooltip的属性,设置鼠标移动到柱子后触发提示,提示该该同学的分数为多少分。
根据配置手册中toolbox.feature的属性,设置工具栏功能,需要由保存图片,数据视图工具,配置项还原,数据区域缩放,动态类型切换。并实验以上功能。
现在我们有该班同学的数学对应成绩96,52,72,25,85,58,83,73,请将数学成绩与语文成绩一同展示,并让老师可以根据自己的需要来单独查看某门课程的统计图。请用legend的功能实现
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>ECharts</title>
<!-- 引入 echarts.js -->
<script src="echarts.min.js"></script>
</head>
<body>
<!-- 为ECharts准备一个具备大小(宽高)的Dom -->
<div id="main" style="width: 600px;height:400px;"></div>
<script type="text/javascript">
// 基于准备好的dom,初始化echarts实例
var myChart = echarts.init(document.getElementById('main'));
// 指定图表的配置项和数据
var option = {
title:{
link:'https://echarts.apache.org/zh/option.html#title',
text:'成绩显示',
textStyle:{
color:'orange'
},
borderWidth:5,
borderColor:'orange',
borderRadius:20,
left:150
},
toolbox: {
show: true,
feature: {
dataZoom: {
yAxisIndex: "none"
},
dataView: {
readOnly: false
},
magicType: {
type: ["line", "bar"]
},
restore: {},
saveAsImage: {}
}
},
legend: {
type: "scroll"
},
tooltip: {
trigger:'item',
triggerOn:'mousemove',
// formatter:'{b}:{c}',
formatter:function(arg){
console.log(arg)
return arg.name + '的成绩是:' + arg.data
}
},
color: ["blue", "green"],
dataset: {
source: [
["姓名", "张三","李四","王五","闰土","小明","茅台","二妞","大强"],
["语文", 88,92,63,77,94,80,72,86],
["数学", 96,52,72,25,85,58,83,73],
]
},
legend: {},
xAxis: {
type: "category",
axisTick: {
show: false
}
},
yAxis: {},
series: [{
type: "bar",
seriesLayoutBy: "row"
}, {
type: "bar",
seriesLayoutBy: "row"
}]
};
// 使用刚指定的配置项和数据显示图表。
myChart.setOption(option);
</script>
</body>
</html>