ECharts使用记
系统开发厂商一直都使用基于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},
]
});
放一张效果图

后续优化
- 首先是实现动态读取服务器数据,即ajax方式。考虑采用jquery库
- 优化图表模版,实现动态坐标轴等功能,和更多自定义配置
- 优化图层显示,实现图表轮播,最大化等功能
ECharts使用记的更多相关文章
- echarts+百度地图+vue 填坑记(一)(百度地图、鼠标移入移出标注,信息框会产生闪烁)
大概七月底开始实习,到现在经历了两个完整的项目(c2b). 因为开发时间紧,任务重,所以在开发过程踩到的坑都没时间去记录. 现在在开发一个某链运输监控系统,到了收尾阶段,有时间写博客了!开心! 一.鼠 ...
- 关于echarts的那些事(地图标点,折线图,饼图)
前记:离上一篇博客的发布已经过去两个月了,这期间总想写点什么,却怎么都写不出来,一直拖到了现在.现在的感觉,不是像这期间一样,想好好整理一番,写一篇好博客,却写不出来.事实发现,随心就好,较好的博客, ...
- echarts词云引用
最近项目中需要使用echarts的词云图,因为几经波折才引用成功,所以想记下来跟大家分享,(我的随笔不会写那么多让人需要动脑子去理解的东西,就是记录一下步骤,因为经验甚少,底层原理懂得不多,所以就先记 ...
- Echarts报错 Can't read property 'getWidth' of null
统计图报错: 这里的报错与echarts无关,与zrender有关,zrender是echarts依赖的canvas绘图库 你不需要了解zrender,这个问题是你代码出了错 谨记::代码的错
- 移动端引用echarts的折线图
移动端写一个图表引用echarts,highcharts插件,本次要找一个能够显示最新数据的折线图,最后只找到显示最大值: 找到echarts的实例:记一下个各功能. <!DOC ...
- echarts 数据统计报表
官网 http://echarts.baidu.com/index.html 我们下载好开发包后就可以开始了,第一步引入开发包,和需要的主题文件(可定义自己的主体文件),并定义好页面布局.2.0以 ...
- 一起来玩echarts系列(一)------箱线图的分析与绘制
一.箱线图 Box-plot 箱线图一般被用作显示数据分散情况.具体是计算一组数据的中位数.25%分位数.75%分位数.上边界.下边界,来将数据从大到小排列,直观展示数据整体的分布情况. 大部分正常数 ...
- Spark踩坑记——Spark Streaming+Kafka
[TOC] 前言 在WeTest舆情项目中,需要对每天千万级的游戏评论信息进行词频统计,在生产者一端,我们将数据按照每天的拉取时间存入了Kafka当中,而在消费者一端,我们利用了spark strea ...
- Webstorm+Webpack+echarts构建个性化定制的数据可视化图表&&两个echarts详细教程(柱状图,南丁格尔图)
Webstorm+Webpack+echarts ECharts 特性介绍 ECharts,一个纯 Javascript 的图表库,可以流畅的运行在 PC 和移动设备上,兼容当前绝大部分浏览器(I ...
随机推荐
- Identity-第一章
本篇文章内容搭建Identity项目,实现几个用户基本的功能,了解Identity具体是什么. 一.Identity入门 Identity是微软在ASP.NET应用程序中管理用户的一个新的API. 1 ...
- JSF学习四 标签
commandButton:提交.重置或下压button button:用于公布GET请求的按钮
- mysql strace fsync,fdatasync
mysql> show create table y; +-------+------------------------------------------------------------ ...
- 系统调用表 linux 2.6.32
[root@localhost log]# find / |grep syscall_table /usr/src/kernels/linux-/arch/x86/kernel/syscall_tab ...
- 常用工具之stunnel
The stunnel program is designed to work as an SSL encryption wrapper between remote client and local ...
- 文件处理-Directory类 (C#)
转http://skybirdzw.blog.163.com/blog/static/7257062620099751329403/ 文件处理-Directory类 (C#) Directory.Cr ...
- Linux环境下搭建Android开发环境
最近在折腾linux.因为咱是搞安卓开发的,所以少不了需要搭建Android开发环境,就此小记,希望能给向我一样的开发者一点帮助!开干! 1.安装JDK 下载JDK包,得到的是类似于jdk-8u65- ...
- react 编写组件 五
看以下示例了解如何定义一个组件 // 定义一个组件LikeButton var LikeButton = React.createClass({ // 给state定义初始值 getInitialSt ...
- 百思不得其解—这些年做Web开发遇到的坑?
请教一个问题:Bootstrap 模态框modal里面的嵌入 iframe ,然后iframe 里面载入的是优酷的视频 ,现在的问题是:这个模态框在谷歌浏览器上面可以播放出视频,而在ff浏览器里面无 ...
- JVM内存模型及垃圾回收机制
http://blog.csdn.net/zhangpengju999/article/details/11773183 JVM垃圾回收机制 分代垃圾回收 不同的对象生命周期不同.与业务信息有关的对象 ...