最近在用echarts做项目,抽点时间总结一下。

  首先说一下什么是echarts。echarts是百度开发的类似于fusioncharts的图表展示控件。区别于fusioncharts的是echarts是基于html5的,不需要浏览器安装flash控件。只需要浏览器支持HTML5即可。

  echarts主页:http://echarts.baidu.com/

  echarts效果展示:http://echarts.baidu.com/doc/example.html?qq-pf-to=pcqq.c2c

  echarts属性解读:http://echarts.baidu.com/doc/doc.html#Legend

  先贴一个代码实例:

<body>
<div id="main" style="height:800px;"></div><!--图表展示位置DIV-->
<script type="text/javascript">
// 路径配置
require.config({
paths: {
echarts:'asset/echarts'//echarts路径
}
}); // 使用
require(
[
'echarts',
'echarts/chart/bar',
'echarts/chart/line',
'echarts/chart/pie'    //使用的Echart类型,可在下面data部分查看。
],
function(ec){
var myChart = ec.init(document.getElementById('main'));//根据ID获取用于展示的DIV
option = {
title : {
text: '未来一周气温变化',    //图表标题
subtext: '纯属虚构'       //图表副标题
},
tooltip : {
trigger: 'axis'
},
legend: {
data:['最高气温','最低气温']  //图例
},
toolbox: {              //工具
show : true,
feature : {
mark : {show: true},
dataView : {show: true, readOnly: false},
magicType : {show: true, type: ['line', 'bar']},
restore : {show: true},
saveAsImage : {show: true}
}
},
calculable : true,
xAxis : [              //X轴展示的内容
{
type : 'category',
boundaryGap : false,
data : ['周一','周二','周三','周四','周五','周六','周日']
}
],
yAxis : [              //y轴坐标
{
type : 'value',
axisLabel : {
formatter: '{value} °C'
}
}
],
series : [              //具体展示内容
{
name:'最高气温',                //展示内容1对应的图例
type:'line',                  //图表类型,需根据该类型引入相应的js
data:[11, 11, 15, 13, 12, 13, 10],     //图表内容
markPoint : {                 
data : [
{type : 'max', name: '最大值'},
{type : 'min', name: '最小值'}
]
},
markLine : {
data : [
{type : 'average', name: '平均值'}
]
}
},
{
name:'最低气温',
type:'line',
data:[1, -2, 2, 5, 3, 2, 0],
markPoint : {
data : [
{name : '周最低', value : -2, xAxis: 1, yAxis: -1.5}
]
},
markLine : {
data : [
{type : 'average', name : '平均值'}
]
}
}
]
};
myChart.setTheme("macarons");      //设置echarts的主题
myChart.setOption(option);        //在DIV上绘制图表
});
</script>
</body>

  下面就如何使用该控件进行一步一步讲解:

  首先引入echarts.js该js文件

  然后再页面中定义好需要展示图表的div的位置,并设置唯一ID。

  然后引入上图中的js代码块,修改相应的代码就OK了。

  修改代码前可以去echarts效果展示中查看相应的效果图,适用于自己的点进去复制左侧的代码,替换代码块中的option。然后添加用到的echarts类型相应的js。

应用过程中遇到的问题:

  1、堆叠式柱状图数据过于密集时数字重叠。

     解决方法:控制展示数据,当小于某个数时不展示,将下面代码添加到series中,修改if else 条件。

itemStyle: {
  normal: {
  label : {
  show: true, position: 'insideTop',
formatter:function(value){
  if(value.data<=2)
  return "";
else
return value.data;
}
}
}
},

  2、滚动条太高,覆盖数据

    解决方法:设置滚动条高度。

dataZoom : {
show : true, //滚动条是否展示
start : 0,  //滚动条开始位置--百分比
end : 25,  //滚动条结束为止--百分比
height:20  //滚动条高度
},

  3、y轴太窄,数据显示不全

    解决方法:控制图像面板的位置,使坐标轴区域面积变大。

grid: {
x: 110    //面板的开始位置,距div左侧的像素数
},

  4、点击柱子或节点相应事件

myChart.on("click",function(params,ctx){  if(params.seriesName=="图例"){//如果点击的柱子或节点是图例中的一个的时候,相应事件
    //事件
    }
  });
});

  5、控制鼠标悬浮显示内容,下面代码是控制如果是负数的时候显示正数。

tooltip : {
  trigger: 'item',
  formatter: function (params){
    if(params.value<=0)
      return params.name + '<br/>'+ params.seriesName + ' : ' + params.value*(-1);
    else
      return params.name + '<br/>'+ params.seriesName + ' : ' + params.value;
  }
},

echarts之我用的更多相关文章

  1. 一起来玩echarts系列(一)------箱线图的分析与绘制

    一.箱线图 Box-plot 箱线图一般被用作显示数据分散情况.具体是计算一组数据的中位数.25%分位数.75%分位数.上边界.下边界,来将数据从大到小排列,直观展示数据整体的分布情况. 大部分正常数 ...

  2. Webstorm+Webpack+echarts构建个性化定制的数据可视化图表&&两个echarts详细教程(柱状图,南丁格尔图)

    Webstorm+Webpack+echarts   ECharts 特性介绍 ECharts,一个纯 Javascript 的图表库,可以流畅的运行在 PC 和移动设备上,兼容当前绝大部分浏览器(I ...

  3. ASP.NET MVC5+EF6+EasyUI 后台管理系统(67)-MVC与ECharts

    系列目录 ECharts 特性介绍 ECharts,一个纯 Javascript 的图表库,可以流畅的运行在 PC 和移动设备上,兼容当前绝大部分浏览器(IE8/9/10/11,Chrome,Fire ...

  4. echarts+php+mysql 绘图实例

    最近在学习php+mysql,因为之前画图表都是直接在echart的实例demo中修改数据,便想着两相结合练习一下,通过ajax调用后台数据画图表. 我使用的是echart3,相比较第二版,echar ...

  5. 数据图表插件Echarts(一)

    一.引言 最近做一个智慧城市项目,项目中需要图表和报表进行数据分析,从网上找了很多,最后找到了百度开放的echarts,一个很强大的插件. 二.介绍 ECharts,缩写来自Enterprise Ch ...

  6. ECharts数据图表系统? 5分钟上手!

    目录: 前言 简介 方法一:模块化单文件引入(推荐) 方法二:标签式单文件引入 [前言] 最近在捣鼓各种插件各种框架,发现这个ECharts还是比较不错的,文档也挺全的,还是中文的,给大家推荐一下. ...

  7. knockout+echarts实现图表展示

    一.需要学习的知识 knockout, require, director, echarts, jquery.简单的入一下门,网上的资料很多,最直接就是进官网校习. 二.效果展示 三.require的 ...

  8. ECharts 初识(基于MVC+jQuery+Angularjs实现的Demo)

    一.背景:      我们这行做web开发的,很多时候都需要做数据统计报表,现在我所使用的是来自百度团队的ECharts.官方网址:http://echarts.baidu.com/      我们知 ...

  9. Ionic2系列——在Ionic2中使用ECharts

    在群里看到有人问怎么在Ionic2中集成ECharts来显示图表.当时答应说写个blog,简单写下步骤. 在TypeScript中如果要使用第三方库,必须要有d.ts,也就是定义文件,没有这个文件的话 ...

  10. ECharts的简单使用过程

    网页中经常要使用图表,以前使用的是highcharts插件,现在发现echarts使用起来和highcharts差不多,但是个人感觉echarts更酷炫,以下是echarts的使用过程,其实highc ...

随机推荐

  1. activiti自己定义流程之Spring整合activiti-modeler5.16实例(四):部署流程定义

    注:(1)环境搭建:activiti自己定义流程之Spring整合activiti-modeler5.16实例(一):环境搭建         (2)创建流程模型:activiti自己定义流程之Spr ...

  2. 三元表达式之理解/jquery源代码分析之$.inArray实现

    每次看到三元表达式就会惶惶然分不清怎样读,正如语文中的断句一样,jquery源代码中的三元表达式更是不知怎样断句. 附jquery中的inArray实现. 大家熟悉jquery的应该都不陌生inArr ...

  3. my.os.ClickThisWindow.ClickThisPoint.py

    my.os.ClickThisWindow.ClickThisPoint.py

  4. 【Codevs 1376】帕秋莉•诺蕾姬

    http://codevs.cn/problem/1376/ 枚举修改哪两位,将sum减去之前位置的数+交换之后  %m==0即可 预处理26的次方+O(n^2) // <1376.cpp> ...

  5. 迟到的WC2019打铁祭

    这是我最失败的一次考试... 具体过程就不说了,全程划水,掉线.还是自身实力不行啊. 最后文艺汇演,本人是DL24主唱&&rapper,欢迎大家交友.^_^.

  6. Python中关键字global与nonlocal的区别

    版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/xCyansun/article/details/79672634终于下定决心学习Python了.既然 ...

  7. WPF获取原始控件样式

    要获取WPF控件的原始样式,需要我们安装Blend for Visual Studio. 然后,我们打开Blend for Visual Studio,创建一个WPF项目. 然后,我们向页面拖动一个B ...

  8. 51Nod 1486 大大走格子 —— 容斥

    题目:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1486 对于每个点,求出从起点到它,不经过其他障碍点的方案数: 求一 ...

  9. bzoj1016 [JSOI2008]最小生成树计数——Kruskal+矩阵树定理

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1016 从 Kruskal 算法的过程来考虑产生多种方案的原因,就是边权相同的边有一样的功能, ...

  10. emma中文显示乱码问题解决

    在Linux中如果使用mysql的图形客户端,个人感觉Emma还不错.但是emma默认用apt-get 安装的话,emma是不支持中文的,这个需要自己修改一下了配置文件,或者直接修改emma程序源文件 ...