系统开发厂商一直都使用基于Flash的图表解决方案,例如Fushioncharts。本人也曾略做研究,当时对js不熟,只能采用静态xml方式,颇为繁琐。

自从了解了html5的新特性,意识到基于Canvas的图表套件可行,于是通过搜索找到ECharts这个项目。该项目是百度旗下的开源js库。试用之后觉得很方便,呈现效果出色,定制功能也丰富,遂投入应用。从技术角度,基于html5的图表比Flash更先进一些,用户感知更好。

虽然我的js还是菜鸟水平,但也摸索出一个实现方案,现作一些记录。

数据来源

因我还未学会Ajax的动态获取方式,故只能将数据表带在页面源代码中。

一是将数据保存为html表格,包含在页面。

<?php include_once "r/Dublin_MME_Sh_dailygraph_".$d_date.".html"; ?>

一是服务器端连接数据库数据。目前实现了连接mysql和informix。

<?php
$mdb_server = "localhost";
$mdb_user = "***";
$mdb_pwd = "XXX";
$mdb_name = "AAA"; $mdb_conn = mysql_connect($mdb_server,$mdb_user,$mdb_pwd);
$mdb_sql = 'select * from zurich where CDATE like "'.$cur_month.'%";';
$mdb_sel = mysql_select_db($mdb_name);
$mdb_res = mysql_query($mdb_sql, $mdb_conn); echo "<table id='MData'>";
while ($mdb_row = mysql_fetch_array($mdb_res)) {
echo "<tr>";
for($idx=0;$idx< sizeof($mdb_row) ;$idx++) {
echo "<td>".$mdb_row[$idx]."</td>";
}
echo "</tr>";
}
echo "</table>";
?>

数据获取

ICharts基于js,是客户端代码,需要从页面代码中抓取数据。采用dom方式简易实现。有待优化。

var str_date = document.getElementById('PageTitle').innerHTML;
/(\d+)/.test(str_date);
str_date = "T"+RegExp.$1;
var row_x = document.getElementById(str_date).rows[0].cells;
var row_y1 = document.getElementById(str_date).rows[1].cells;
var row_y2 = document.getElementById(str_date).rows[2].cells;
var row_y3 = document.getElementById(str_date).rows[3].cells; var str_pinshi = document.getElementById('Pinshi').innerHTML;
/(\d+)/.test(str_pinshi);
str_pinshi = "T"+RegExp.$1;
var row_b18 = document.getElementById(str_pinshi).rows[18].cells; var a_x = [],a_y1 = [],a_y2 = [],a_y3 = [],a_y4 = [];
var a_b18 = [];
for (var i = 1;i<=row_x.length - 1; i++) {
a_x.push(row_x[i].innerHTML);
a_b18.push(row_b18[i].innerHTML);
};
for (var i = 1;i<=int_neartime; i++) {
a_y1.push(row_y1[i].innerHTML);
a_y2.push(row_y2[i].innerHTML);
a_y3.push(row_y3[i].innerHTML);
};

图表呈现

icharts的工作原理非常清晰易懂,只要定义画布,调用js函数作画,指定数据和图表属性即可。

<div id="myGraph1" style="height:300px;width:99%;border:1px solid #ccc;"></div> 
    var myChart1 = echarts.init(document.getElementById('myGraph1'));
myChart1.setOption({
title : {text: 'EPS附着成功率'},
legend : {data:['EPS附着成功率','附着次'],y:'bottom'},
tooltip : {trigger: 'axis'},
toolbox: {
show : true,
feature : {
mark : false,
dataView : {readOnly: false},
magicType:['line', 'bar'],
restore : true,
saveAsImage : true
}
},
xAxis : [{type : 'category',data :a_x,axisLabel:{interval:0,rotate:-90,}}],
yAxis : [{max:100,type : 'value',position:'left', splitArea : {show : true}},{type : 'value',position:'right', splitArea : {show : false}}],
series : [
{name:'EPS附着成功率',type:'line',data:a_y2},
{name:'附着次',type:'bar',data:a_y1,yAxisIndex:1},
]
});

放一张效果图

后续优化

  1. 首先是实现动态读取服务器数据,即ajax方式。考虑采用jquery库
  2. 优化图表模版,实现动态坐标轴等功能,和更多自定义配置
  3. 优化图层显示,实现图表轮播,最大化等功能

ECharts使用记的更多相关文章

  1. echarts+百度地图+vue 填坑记(一)(百度地图、鼠标移入移出标注,信息框会产生闪烁)

    大概七月底开始实习,到现在经历了两个完整的项目(c2b). 因为开发时间紧,任务重,所以在开发过程踩到的坑都没时间去记录. 现在在开发一个某链运输监控系统,到了收尾阶段,有时间写博客了!开心! 一.鼠 ...

  2. 关于echarts的那些事(地图标点,折线图,饼图)

    前记:离上一篇博客的发布已经过去两个月了,这期间总想写点什么,却怎么都写不出来,一直拖到了现在.现在的感觉,不是像这期间一样,想好好整理一番,写一篇好博客,却写不出来.事实发现,随心就好,较好的博客, ...

  3. echarts词云引用

    最近项目中需要使用echarts的词云图,因为几经波折才引用成功,所以想记下来跟大家分享,(我的随笔不会写那么多让人需要动脑子去理解的东西,就是记录一下步骤,因为经验甚少,底层原理懂得不多,所以就先记 ...

  4. Echarts报错 Can't read property 'getWidth' of null

    统计图报错: 这里的报错与echarts无关,与zrender有关,zrender是echarts依赖的canvas绘图库 你不需要了解zrender,这个问题是你代码出了错 谨记::代码的错

  5. 移动端引用echarts的折线图

          移动端写一个图表引用echarts,highcharts插件,本次要找一个能够显示最新数据的折线图,最后只找到显示最大值: 找到echarts的实例:记一下个各功能.   <!DOC ...

  6. echarts 数据统计报表

    官网   http://echarts.baidu.com/index.html 我们下载好开发包后就可以开始了,第一步引入开发包,和需要的主题文件(可定义自己的主体文件),并定义好页面布局.2.0以 ...

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

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

  8. Spark踩坑记——Spark Streaming+Kafka

    [TOC] 前言 在WeTest舆情项目中,需要对每天千万级的游戏评论信息进行词频统计,在生产者一端,我们将数据按照每天的拉取时间存入了Kafka当中,而在消费者一端,我们利用了spark strea ...

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

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

随机推荐

  1. Android应用换肤总结

    换肤,我们都很熟悉,像XP的主题,塞班的主题.看过国外的一些技术博客,就会发现国内和国外对软件的,或者说移动开发的软件的需求的不同.国外用户注重社交.邮件等功能,国内用户则重视音乐.小说.皮肤等功能, ...

  2. 我这个IOS渣渣又来写随笔了

    我这个渣渣又来写了,哎,今天看了一篇大神面试别人的文章,感觉还有很遥远的路要走,不过没关系,还年轻,才入ios两个月,我相信自己的学习能力,加油! 博客园会是我成长的见证!

  3. webstrom热键[持续更新]

    1.Ctrl+ Shift + A  --  为了加快寻找菜单命令或工具栏操作,你并不需要看菜单.只有按Ctrl+ Shift + A(说明|查找操作主菜单上),并开始输入动作的名称. . 2.Ctr ...

  4. JavaScript引擎的工作原理

    http://my.oschina.net/fuckBAT/blog/318355?fromerr=jK6wCh1p#OSC_h4_4

  5. 标准I/O库之格式化I/O

    本篇博文内容摘自<UNIX环境高级编程>(第二版),仅作个人学习记录所用.关于本书可参考:http://www.apuebook.com/. 一.格式化输出 执行格式化输出处理的是4个pr ...

  6. 常用工具之zabbix

    简介 zabbix(音同 zæbix)是一个基于WEB界面的提供分布式系统监视以及网 络监视功能的企业级的开源解决方案. zabbix能监视各种网络参数,保证服务器系统的安全运营:并提供灵活的通知机制 ...

  7. Android(java)学习笔记161:Framework运行环境之启动SystemServer进程

          SystemServer进程是zygote孵化出的第一个进程,该进程是从ZygoteInit.java的main函数中调用startSystemServer()开始的.与启动普通进程的差别 ...

  8. iOS UIKit:TableView之编辑模式(3)

    一般table view有编辑模式和正常模式,当table view进入编辑模式时,会在row的左边显示编辑和重排控件,如图 42所示的编辑模式时的控件布局:左边的editing control有表 ...

  9. Python中如何写控制台进度条的整理

    本文实例讲述了Python显示进度条的方法,是Python程序设计中非常实用的技巧.分享给大家供大家参考.具体方法如下: 首先,进度条和一般的print区别在哪里呢? 答案就是print会输出一个\n ...

  10. FTP上传下载

    使用的是apache开源包commons-net-3.3.jar所提供的FTPClient FTP服务器使用Quick Easy FTP Server 4.0.0(服务器ip为192.168.31.1 ...