在项目中开发图表功能时用到了Echars和一个关于Echars的java类库(http://git.oschina.net/free/ECharts)。这个类库主要目的是方便在Java中构造ECharts中可能用到的数据结构,即我们可以直接在后端构造好一个Option对象(java对象),将其转换为JSON字符串后返回给前端。但是在Echarts中的Option配置项中,通常需要配置一些函数类型的参数,在后端构造的Option对象只能以拼接字符串的方式在传递函数类型的参数,这样拼接不仅繁琐,而且通过使用java提供的一些Json工具包将后台构造的Option对象转换为json字符串时容易出现错误。所以我对Echars进行了简单的封装,如下代码:

/*
* Created by liubaozhe on 2016/7/20.
*/
function EcharsFun(){
this.cfg={
echartsInitDom:null, //初始化DOM节点,jquery对象类型 (必选)
ajaxUrl:null, //ajax 提交路径(必选)
ajaxParam:{}, //ajax 参数(必选)
ajaxSuccess:null, //ajax请求成功回调函数
option :null,//option 对象参数
isResize:true //是否根据窗口大小改变图表大小
}
}
EcharsFun.prototype=$.extend({},{
doAjax:function(){
var that=this;
$.ajax({
url: that.cfg.ajaxUrl,
type: "POST",
data:that.cfg.ajaxParam,
dataType :"json",
error: function(XMLHttpRequest, textStatus, errorThrown) {
that.error(XMLHttpRequest, textStatus, errorThrown);
},
success: function(data){
that._success(data);
},
beforeSend: function() {//请求前回调函数
that.beforeSend();
},
complete:function(XMLHttpRequest, textStatus) { //请求完成回调函数
that.complete(XMLHttpRequest, textStatus);
}
});
},
beforeSend:function(){
var that=this;
that._myChart.clear();
that._myChart.showLoading({
text: '正在努力的读取数据中...' //loading话术
})
},
complete:function(){
var that=this;
that._myChart.hideLoading();
},
_success:function(data){
var that=this;
var option={};
if(data && data.option){
option = $.parseJSON(data.option);
}
//如果option对象不为空,进行合并参数
if(!$.isEmptyObject(option)) {
$.extend(true,option, that.cfg.option); //合并option
}
//设置ajax回调函数
that.cfg.ajaxSuccess && that.cfg.ajaxSuccess(data);
//设置option
that._myChart.setOption(option,true);
},
error:function (error) {
console.error("图表请求数据失败!");
},
initEcharts:function() {
var that = this;
that._myChart = echarts.init(that.cfg.echartsInitDom[0]);
},
bindEvent:function(){ //绑定UI事件
var that=this;
if(that.cfg.isResize){
window.onresize = that._myChart.resize;
}
},
init:function(cfg){
var that=this;
that._myChart=null;
$.extend(that.cfg,cfg);
that.initEcharts();
that.doAjax();
that.bindEvent();
}
});

  

使用方法:

 var echars = new EcharsFun();
echars.init({
echartsInitDom: $('#issue-total-bar'),
ajaxUrl:createIssueTotalPie.do, //ajax 提交路径(必选)
ajaxParam: $('from').serializeObject(),
isResize: true //是否根据窗口大小改变图表大小
});

  

如果需要配置函数参数,和正常配置Echarts 的option一样,这里的配置项优先级高,会覆盖后端生成的配置:

 var echars = new EcharsFun();
echars.init({
echartsInitDom: $('#issue-total-bar'),
ajaxUrl:createIssueTotalPie.do, //ajax 提交路径(必选)
ajaxParam: $('from').serializeObject(),
option: {
series: [
{
itemStyle: {
normal: {
label: {
formatter: function (params) {
return params.name + ':' + params.value + '\n占比:' + params.percent + '%';
}
}
},
emphasis: {
label: {
formatter: function (params) {
return params.percent + '%';
}
}
}
}
}
]
},
isResize: true //是否根据窗口大小改变图表大小
});

结束:欢迎指出我文中的错误和不足,在此先行谢过了☆⌒(*^-゜)v

关于ECharts Java类库的一个jquery插件的更多相关文章

  1. 做了一个jquery插件,使表格的标题列可左右拉伸

    示例下载 插件名称命名为:jquery.tableresize.js,代码如下: /* Writen by mlcactus, 2014-11-24 这是我封装的一个jquery插件,能够使table ...

  2. Jquery 类似新浪微博,鼠标移到头像,用浮动窗口显示用户信息,已做成一个jquery插件

    请注意!!!!! 该插件demo PHP 的 demo下载  C#.NET的demo下载 需要如下图, 1.鼠标移动到头像DIV时,Ajax获取数据,并让浮动DIV显示出来. 2.鼠标可以移动到上面浮 ...

  3. 如何写一个jquery插件

      本文总结整理一下如何写一个jquery插件?虽然现今各种mvvm框架异常火爆,但是jquery这个陪伴我们成长,给我们带来很多帮助的优秀的库不应该被我们抛弃,写此文章,作为对以往欠下的笔记的补充, ...

  4. 你真的需要一个jQuery插件吗

    jQuery的插件提供了一个很好的方法,节省了时间和简化了开发,避免程序员从头开始编写每个组件.但是,插件也将一个不稳定因素引入代码中.一个好的插件节省了无数的开发时间,一个质量不好的插件会导致修复错 ...

  5. 如何去定义一个jquery插件

    扩展jquery的时候.最核心的方法是以下两种: $.extend(object) 可以理解为jquery添加一个静态方法 $.fn.extend(object) 可以理解为jquery实例添加一个方 ...

  6. 开发一个jQuery插件——多级联动菜单

    引言 开发中,有好多地方用到联动菜单,以前每次遇到联动菜单的时候都去重新写,代码重用率很低,前几天又遇到联动菜单的问题,总结了下,发现可以开发一个联动菜单的功能,以后想用的时候就方便多了.项目中每个页 ...

  7. 自己实现一个jQuery插件

    <script src="https://cdn.staticfile.org/jquery/2.0.3/jquery.min.js"></script> ...

  8. 如何使用jQuery写一个jQuery插件

    jQuery插件其实是前端框架的思维,构成一个框架,个人认为必须满足以下几个基础条件:1. 可重用,2. 兼容性,3. 维护方便,虽说现在有很多比较成熟的前端框架,但是也有部分存在配置麻烦,学习成本大 ...

  9. 我的第一个jquery插件:下拉多选框

    <!DOCTYPE HTML> <html> <head> <title> New Document </title> <meta n ...

随机推荐

  1. asp.net中Repeart选中整行操作

    <asp:Repeater runat="server" ID="rpt_Student"> <HeaderTemplate> < ...

  2. pl_sql 报ora-12154 无法解析指定的连接标识符的问题

    情况一:连接本地的没有问题,连接远程服务器的时候报以上错误.那么在本地客户端下的TNSNames.ora设置中配置你的远程服务器连接,本人的如下: //mestest是远程服务器名 //172.18. ...

  3. css3动画学习的例子来源

    1.这里面有不同的鼠标经过图片效果,图片变大变小,出现文字,向左移动等等 http://dinolatoga.com/demo/webkit-image-hover-effects/ 2.有一篇博客, ...

  4. wpf中,一个简单的自定义treeview

    首先创建一个自定义控件,在里面定义好treeview的样式,将本来的三角形的图标变为加号的图标,并且添加节点之间的连线. <UserControl x:Class="TreeViewE ...

  5. android使用友盟第三方自动更新/手动更新

    最近项目用到自动更新,发现一个方便快捷的第三方组件非常好用,只需要几行代码搞定,非常适合新手使用.分享给大家一起学习. 本文档帮助您以最快速最简洁的方式集成使用自动更新组件. 一.申请友盟开发者账号创 ...

  6. Android开发_关于如何屏蔽Home键

    今天在遇到一个要屏蔽Home键的问题,研究一上午终于解决,方法记录于下: 在Android2.3版本以下重写以下方法就能屏蔽Home键: public void onAttachedToWindow( ...

  7. HDU 5727 - Necklace

    题意:( 0 <= n <= 9 )    现在有n颗阴珠子和n颗阳珠子,将它们阴阳相间圆排列构成一个环,    已知有些阴珠子和阳珠子不能放在相邻的位置,否则这颗阳珠子就会失去功效,   ...

  8. avalon中常用的事件

     ms-on-change 相当于失去焦点事件. ms-on-input 相当于watch事件 http://www.runoob.com/jsref/event-oninput.html

  9. pom文件详解

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/20 ...

  10. 常用工具类,文件和内存的大小获取,shell脚本的执行

    /* * Copyright (C) 2012 The Android Open Source Project * * Licensed under the Apache License, Versi ...