在JSP页面制作柱状图,可以根据数据的变化动态实时的变化

主要是使用EXTJS自带的插件达到效果

Ext.require('Ext.chart.*');
Ext.require([ 'Ext.Window', 'Ext.fx.target.Sprite', 'Ext.layout.container.Fit', 'Ext.window.MessageBox' ]);

然后编写显示的位置(模板)

        var chartComMonthBudgetPanel = Ext.create('Ext.Panel', {
id : 'chartComMonthBudgetPanel',
// store : matDeptMonthBudgetStore,
title : '预算分解情况',
frame : true });

在需要的地方展示出来,我将代码打包写在函数里,我自己在业务中调用查询

function _selectMatDeptMonthBudget() {
var records = Ext.getCmp('comMatBudgetCatPanel').getSelectionModel().getSelection(); if (Ext.getCmp('YEAR_').getValue() == null) {
Ext.MessageBox.show({
title : '提示',
msg : '请输入年份',
buttons : Ext.MessageBox.OK,
icon : Ext.MessageBox.WARNING
});
return false;
} if (records.length == 0) {
Ext.MessageBox.show({
title : '提示',
msg : '请选择物料预算分类',
buttons : Ext.MessageBox.OK,
icon : Ext.MessageBox.WARNING
});
return false;
} if (Ext.getCmp('DEPT_CODE_').getValue() == null) {
Ext.MessageBox.show({
title : '提示',
msg : '请选择作业区',
buttons : Ext.MessageBox.OK,
icon : Ext.MessageBox.WARNING
});
return false;
} Ext.Ajax.request({
url : 'loadMat.do',
type : 'ajax',
method : 'POST',
params : {
'YEAR_' : Ext.getCmp('YEAR_').getValue(),
'MAT_BUDGET_CAT_ID_' : records[0].get('MAT_BUDGET_CAT_ID_'),
'DEPT_CODE_' : Ext.getCmp('DEPT_CODE_').getValue()
},
callback : function(options, success, response) {
if (success) {
var data = Ext.decode(response.responseText);
if (data.success) {
matDeptYearBudget = data.matDeptYearBudget;
if (matDeptYearBudget != null) {
Ext.getCmp('DEPT_YEAR_BUDGET_').setValue(matDeptYearBudget.BUDGET_);
} else {
Ext.getCmp('DEPT_YEAR_BUDGET_').setValue(0);
}
} else {
Ext.getCmp('DEPT_YEAR_BUDGET_').setValue(0);
}
}
}
}); Ext.Ajax.request({
url : 'select.do',
type : 'ajax',
method : 'POST',
params : {
'YEAR_' : Ext.getCmp('YEAR_').getValue(),
'MAT_BUDGET_CAT_ID_' : records[0].get('MAT_BUDGET_CAT_ID_'),
'DEPT_CODE_' : Ext.getCmp('DEPT_CODE_').getValue()
},
callback : function(options, success, response) {
if (success) {
var data = Ext.decode(response.responseText); if(chartComMonthBudget != null){
Ext.getCmp('chartComMonthBudgetPanel').removeAll(true);
ComMonthBudgetData =[];
} if (data.success) { matDeptMonthBudgetList = data.matDeptMonthBudgetList;
for(var i=1;i<=12;i++){
var a=0;
for(var j = 0; j < matDeptMonthBudgetList.length; j++){
if(matDeptMonthBudgetList[j].MONTH_==i){
ComMonthBudgetData.push({MONTH_ : matDeptMonthBudgetList[j].MONTH_ + '月',MONTH_BUDGET_ : matDeptMonthBudgetList[j].BUDGET_});
a=a+1;
}
}
if(a==0){
ComMonthBudgetData.push({MONTH_: i +'月',MONTH_BUDGET_ : 0});
}
}
} Ext.define('WeatherPoint', {
extend : 'Ext.data.Model',
fields : ['MONTH_BUDGET_','MONTH_']
});
var ComMonthBudgetStore = Ext.create('Ext.data.Store', {
model : 'WeatherPoint',
data : ComMonthBudgetData
}); //主要是此处的代码
chartComMonthBudget = Ext.create('Ext.chart.Chart',{
id : chartComMonthBudget,
height:350,
width:600,
style: 'background:#fff',
animate: true,
shadow: true,
store : ComMonthBudgetStore,
axes: [{
type: 'Numeric',
position: 'left',
fields: ['MONTH_BUDGET_'],
label: {
renderer: Ext.util.Format.numberRenderer('0,0')
},
grid: true,
minimum: 0
}, {
type: 'Category',
position: 'bottom',
fields: ['MONTH_'],
title: '预算分解情况',
minimum: 1
}],
series: [{
type: 'column',
axis: 'left',
highlight: true,
tips: {
trackMouse: true,
width: 140,
height: 28,
renderer : function(storeItem, item) {
this.setTitle(item.value[0] + ': '
+ Ext.util.Format.usMoney(item.value[1]));
}},
label: {
display: 'insideEnd',
// 'text-anchor': 'middle',//这句代码没有,在很多参考地方有,但查资料后不正确,没有。
field: 'MONTH_BUDGET_',
renderer: Ext.util.Format.numberRenderer('0'),
orientation: 'vertical',
color: '#333'
},
xField: 'MONTH_',
yField: 'MONTH_BUDGET_'
}] });
Ext.getCmp('chartComMonthBudgetPanel').add(chartComMonthBudget);
}
}
}); }

我需要处理查询时,在点击查询后,显示最新的数据图,于是使用了代码

if(chartComMonthBudget != null){
Ext.getCmp('chartComMonthBudgetPanel').removeAll(true);
ComMonthBudgetData =[];
}

使每次显示最新的值。

后期对代码做了进一步的优化,由于Ext.chart.Chart本身就是EXTJS的一个组件,可以直接显示,不用放在面板里。对数据的存放做了处理

var matComMonthBudgetStore = Ext.create('Ext.data.Store', {
storeId : 'matComMonthBudgetStore',
autoLoad : false,
pageSize : -1,
fields : [ 'MONTH_', 'MONTH_BUDGET_' ]
});
var matComMonthBudgetChart = Ext.create('Ext.chart.Chart', {
id : 'matComMonthBudgetChart',
store : matComMonthBudgetStore,
title : '预算分解情况',
frame : true,
animate : true,
shadow : true,
axes : [ {
type : 'Numeric',//Numeric轴来展示区域序列数据
position : 'left',//numeric轴放在图表左侧
fields : [ 'MONTH_BUDGET_' ],
label : {
renderer : Ext.util.Format.numberRenderer('0,0')
},
grid : true,//category和numeric轴都有grid集合,水平线和垂直线会覆盖图表的背景
minimum : 0
}, {
type : 'Category',//Category轴来显示数据节点的名字
position : 'bottom',//category轴放在图表下部
fields : [ 'MONTH_' ],
title : '预算分解情况',
minimum : 1
} ],
series : [ {
type : 'column',//显示图形类型- line:则线图;column:柱形图;radar:雷达图
axis : 'left',
highlight : true,//如果设置为真,当鼠标移动到上面时,高亮。
tips : {//为可视化标记添加工具栏
trackMouse : true,
width : 140,
height : 28,
renderer : function(storeItem, item) {
this.setTitle(item.value[0] + ': ' + Ext.util.Format.usMoney(item.value[1]));
}
},
label : {
display : 'insideEnd',//指定饼图标签的位置。包括"rotate", "middle", "insideStart", "insideEnd", "outside", "over", "under", 或者 "none"可以用来渲染标签。
field : 'MONTH_BUDGET_',//标签要展示的字段的名称。
renderer : Ext.util.Format.numberRenderer('0'),
orientation : 'vertical',//"horizontal" 或者 "vertical"
color : '#333'
},
xField : 'MONTH_',
yField : 'MONTH_BUDGET_'
} ]
});
Ext.Ajax.request({
url : 'select.do',
type : 'ajax',
method : 'POST',
params : {
'YEAR_' : Ext.getCmp('YEAR_').getValue(),
'MAT_BUDGET_CAT_ID_' : records[0].get('MAT_BUDGET_CAT_ID_'),
'DEPT_CODE_' : Ext.getCmp('DEPT_CODE_').getValue()
},
callback : function(options, success, response) {
if (success) {
var data = Ext.decode(response.responseText);
if (data.success) {
var matDeptMonthBudgetList = data.matDeptMonthBudgetList;
var matComMonthBudgetStore = Ext.data.StoreManager.lookup('matComMonthBudgetStore');
matComMonthBudgetStore.removeAll();
for (var i = 0; i < 12; i++) {
matComMonthBudgetStore.add({
MONTH_ : (i + 1) + '月',
MONTH_BUDGET_ : (matDeptMonthBudgetList[i].BUDGET_ != null ? matDeptMonthBudgetList[i].BUDGET_ : 0)
});
}
}
}
}
});

欢迎大家阅览,多多评论其中的不足!!

为工程师之路添砖加瓦!!

Extjs 制作柱状图的更多相关文章

  1. Vue整合d3.v5.js制作--柱状图(rect)

    先上效果图: 图中柱状图变成纯蓝色是鼠标滑动过的颜色(颜色可改,本人配色能力十分的强,建议直接用默认设置即可 ( ᖛ ̫ ᖛ )ʃ)) 1.环境说明 Vue版本:"vue": &q ...

  2. 浅谈Extjs radiogroup change事件与items下的checked属性

    在使用Extjs制作crud时,由于添加和修改界面的高度相似,使用了相同的row字段. 在角色字段中使用了change监听事件,用于动态的无效化权限分配字段,因为权限分配界面默认没有隐藏,设定了che ...

  3. Excel中用REPT函数制作图表

    本文从以下七个方面,阐述在Excel中用REPT函数制作图表: 一. 图形效果展示 二. REPT语法解释 三. REPT制作条形图 四. REPT制作漏斗图 五. REPT制作蝴蝶图 六. REPT ...

  4. CSS3 - vue中纯css实现柱状图表效果

    背景 以前我们制作柱状图都用echarts或者其他同类型的图表插件 这次是个移动端的需求,而且这个图表需要动画 使用echarts就会显得过重,而且动画达不到我想要的效果(主要是我自己愚蠢想不到好的动 ...

  5. D3+svg 案例

    <!doctype html><html lang="en"><head> <meta charset="UTF-8" ...

  6. Python 数据图表工具的比较

    Python 的科学栈相当成熟,各种应用场景都有相关的模块,包括机器学习和数据分析.数据可视化是发现数据和展示结果的重要一环,只不过过去以来,相对于 R 这样的工具,发展还是落后一些. 幸运的是,过去 ...

  7. C语言I 博客作业03

    这个作业属于哪个课程 C语言程序设计II 这个作业要求在哪里 作业要求 我在这个课程的目标是 掌握关系运算.if-else语句.格式化输入语句scanf(),以及常用的数学库函数 这个作业在那个具体方 ...

  8. ELK学习实验009:安装kibana的仪表盘

    一 metricbeat仪表盘 1.1 安装metricbeat仪表盘 可以将metricbeat数据在kibana中展示 [root@node4 ~]# cd /usr/local/metricbe ...

  9. ArcMap从建库到出图

    1前言 本篇博主将介绍关于ArcMap建库.数据采集.拓扑检查.图表.制作符号等的基本操作. 2问题阐述 (1)检查现有block(线要素)图层,保证所有要素闭合,并将其转换为parcel(面要素): ...

随机推荐

  1. jboss配置数据源

    配置的是mysql的数据源 找到jboss-.GA\docs\examples\jca\mysql-ds.xml 复制一份到jboss-.GA\server\default\deploy目录下 然后修 ...

  2. iOS重一些常用的代理模式

    (一)代理模式 应用场景:当一个类的某些功能需要由别的类来实现,但是又不确定具体会是哪个类实现.优势:解耦合敏捷原则:开放-封闭原则实例:tableview的 数据源delegate,通过和proto ...

  3. Android Monkey压力测试

    Monkey 是Android SDK提供的一个命令行工具, 可以简单,方便地运行在任何版本的Android模拟器和实体设备上. Monkey会发送伪随机的用户事件流,适合对app做压力测试. 1为什 ...

  4. swift上传头像

    很久没有写博客了,今天特地写了这个,也是一边仿照别人写的demo,注释部分都是需要的.需要的同学可以参考一下. @IBAction func headImageBtnPage(){  //上传头像 / ...

  5. 跟我从零基础学习Unity3D开发--资源打包篇(AssetBundle)

    好久没更新了,一直在加班敢项目进度.这里和关注我的博客的童鞋表示一下歉意!这里有我录的Unity3D从零开始的视频教程大家可以关注一下:http://www.imooc.com/view/555  视 ...

  6. docfx组件介绍--YamlSerialization

    在docfx中把元数据以yaml的形式保存,在metadata阶段会序列化数据到yaml文件中,在build阶段又需要从yaml文件反序列化出来.在使用过程中,意外发现yamldotnet在处理大量强 ...

  7. CloudSim介绍和使用

    本文主要介绍一下我在使用CloudSim时翻译.整理和理解的一些信息,以及我的使用经验,希望能对有需要的朋友们有所帮助~1.我翻译和理解的一些信息:    2009年4月8日,澳大利亚墨尔本大学的网格 ...

  8. HtmlUnit初探

    HtmlUnit是一个用java实现的浏览器,是一个无界面的浏览器(headless browser),跟phatomJS好像是同一类事物. HtmlUnit基于apache httpClient,而 ...

  9. 《Java EE 开发技术与案例教程》 这是一本好书啊:简洁精辟(相见恨晚)

    第一章:Java EE 概述 1.get:JPA:Java Persistence API, 数据持久化API: JPA是一种ORM规范,它的实现实例:Hibernate.mybatis 2.Web ...

  10. 【OpenJudge 191】【POJ 1189】钉子和小球

    http://noi.openjudge.cn/ch0405/191/ http://poj.org/problem?id=1189 一开始忘了\(2^{50}\)没超long long差点写高精度Q ...