早上起来闲逛codops,在它的Web Design & Development News: Collective #149 | Codrops发现了来自百度的数据可视化工具Echarts,貌似功能强大,自己尝试着学习下。
------------------------------------------------------------
--我参加了博客之星评选,如果你喜欢我的博客,求投票,您的支持是我的动力之源,走起!
-----------------------------------------------------------------------------------------
ECharts,缩写来自Enterprise Charts,商业级数据图表,是百度的一个开源的数据可视化工具,业界给予了很多赞誉,这里不多说,需要了解详情的同学参见官网。我简略看了下,最贴切的地方在于本地化支持,比如对于中国地图的支持。
先来一个最简单的案例,实现一个条形图,代码我放在codepen哟,大家可以移步预览效果先。
预先准备好具有宽和高的网页元素,我们将用它绘制数据表。
<div id="main" style="width:600px;height:400px"></div>
然后我们导入Echarts类库,做好准备。
<script src="http://echarts.baidu.com/build/dist/echarts.js"></script>
然后就是重头戏,我们来绘制数据表,首先配置路径,接着使用Echarts开始绘图。
// 路径配置 require.config({ paths: { echarts: ‘http://echarts.baidu.com/build/dist‘ } }); // 使用 require( [ ‘echarts‘, ‘echarts/chart/bar‘, // 使用柱状图就加载bar模块,按需加载 ], function (ec) { // 基于准备好的dom,初始化echarts图表 var myChart = ec.init(document.getElementById(‘main‘)); //设置数据 var option = { }; // 为echarts对象加载数据 myChart.setOption(option); } );
重点是option里的设置,设置坐标轴、设置数据。
var option = { //设置坐标轴 xAxis : [ { type : ‘category‘, data : ["衬衫","羊毛衫","雪纺衫","裤子","高跟鞋","袜子","帽子","围巾"] } ], yAxis : [ { type : ‘value‘ } ], //设置数据 series : [ { "name":"销量", "type":"bar", "data":[5, 20, 40, 10, 24, 20,24,32], } ] };
我们可以设置图标标题、图例、提示等,代码如下,效果如下图所示。
var option = { //设置标题 title:{ text:‘销量图‘, subtext:‘纯属捏造,如有雷同,人品爆发。‘ }, //设置提示 tooltip: { show: true }, //设置图例 legend: { data:[‘销量‘] }, //设置坐标轴 xAxis : [ { type : ‘category‘, data : ["衬衫","羊毛衫","雪纺衫","裤子","高跟鞋","袜子","帽子","围巾"] } ], yAxis : [ { type : ‘value‘ } ], //设置数据 series : [ { "name":"销量", "type":"bar", "data":[5, 20, 40, 10, 24, 20,24,32], } ] };
======================ok,华丽的分割线,之后我来点复杂的==========================
加点料,来电混搭,直线图加上条形图,同时画平均线、提示最大最小值,同样代码放在codepen,移步预览效果先。
当我们需要混搭的时候,首先需要在require里加载需要使用的图库,然后在series里填写折线图的数据就可以了。代码如下,因为注释已经写得很清楚了,就不在啰嗦了,大家直接研究代码。
// 路径配置 require.config({ paths: { echarts: ‘http://echarts.baidu.com/build/dist‘ } }); // 使用 require( [ ‘echarts‘, ‘echarts/chart/bar‘, // 使用柱状图就加载bar模块,按需加载 ‘echarts/chart/line‘ ], function (ec) { // 基于准备好的dom,初始化echarts图表 var myChart = ec.init(document.getElementById(‘main‘)); //设置数据 var option = { //设置标题 title:{ text:‘销量图‘, subtext:‘纯属捏造,如有雷同,人品爆发。‘ }, //设置提示 tooltip: { show: true }, //设置图例 legend: { data:[‘销量‘] }, //设置坐标轴 xAxis : [ { type : ‘category‘, data : ["衬衫","羊毛衫","雪纺衫","裤子","高跟鞋","袜子","帽子","围巾"] } ], yAxis : [ { type : ‘value‘ } ], //设置数据 series : [ //条形图 { "name":"销量", "type":"bar", "data":[5, 20, 38, 10, 24, 20,24,32] }, //折线图 { "name":"销量", "type":"line", "data":[5, 20, 38, 10, 24, 20,24,32], //绘制平均线 markLine : { data : [ {type : ‘average‘, name: ‘平均值‘} ] }, //绘制最高最低点 markPoint : { data : [ {type : ‘max‘, name: ‘最大值‘}, {type : ‘min‘, name: ‘最小值‘} ] } } ] }; // 为echarts对象加载数据 myChart.setOption(option); } );
好了,挺长了,我们下次再研究。
----------------------------------------------------------
前端开发whqet,关注web前端开发,分享相关资源,欢迎点赞,欢迎拍砖。
---------------------------------------------------------------------------------------------------------
原文地址:http://blog.csdn.net/whqet/article/details/42703973