- 浏览: 3416346 次
- 性别:
- 来自: 苏州
文章分类
最新评论
-
sonichy:
Qt5改动很多,要改改了。
基于QItemDelegate的例子1 SpinBoxDelegate -
我的主页6:
楼主,2.2子查询的分页方式:SELECT * FROM ar ...
Mysql 分页语句Limit用法 -
liguoqi:
非常感谢楼主的用心指导,工具以及图片例子都提供了 赞!
两款免费DCIOM 图像浏览软件介绍和DICOM图像例子供下载 -
liguoqi:
问下这个图片怎么解压损坏呀
两款免费DCIOM 图像浏览软件介绍和DICOM图像例子供下载 -
liguoqi:
楼主讲解的非常详细,还附带工具和图片例子,非常感谢
两款免费DCIOM 图像浏览软件介绍和DICOM图像例子供下载
界面如图:
web层js源代码:
//=============================================================================== // Copyright (C) 2010 XXXXXXX有限公司。版权所有。 //=============================================================================== // // 文件名:ComponentCheckExceptionStatistics.js // // 文件描述:web层js文件,部件盘点异常统计 // // // 创建人: truman // 创建时间:2010年4月15日 // 说明: // 修改人: // 修改时间: // 修改描述: //=============================================================================== //===部件盘点异常统计===// function ComponentCheckExceptionStatisticsInfo(){ cmptExcepStatisticsRequestWindow.show();//显示部件盘点异常统计窗口 } //========================部件异常统计store==============================// //==数据解析器 cmptExcepStatisticsRequestReader==// var cmptExcepStatisticsRequestReader = new Ext.data.JsonReader({ totalProperty: 'totalCount', root: 'data', idProperty: 'CHECK_ID' }, [{ name: 'ID', mapping: 'ID' },{ name: 'CHECK_ID', mapping: 'CHECK_ID' }, { name: 'COUNT_EXCEPTION', mapping: 'COUNT_EXCEPTION' }, { name: 'COUNT_CMPT_EXCEPTION', mapping: 'COUNT_CMPT_EXCEPTION' },{ name: 'COUNT_STUFF_EXCEPTION', mapping: 'COUNT_STUFF_EXCEPTION' },{ name: 'BEGIN_TIME', mapping: 'BEGIN_TIME' }, { name: 'END_TIME', mapping: 'END_TIME' }, { name: 'CHECKPLAN_TIME', mapping: 'CHECKPLAN_TIME' }]); //==代理cmptExcepStatisticsRequestProxy==// var cmptExcepStatisticsUrlPath = '../../../Url/Warehouse/CheckWarehouse/GetComponentsCheckExceptionStatistics.aspx';// 请求的页面 var cmptExcepStatisticsRequestProxy = new Ext.data.HttpProxy({ url: cmptExcepStatisticsUrlPath }); //==存储器cmptExcepStatisticsStore==// var cmptExcepStatisticsStore = new Ext.data.Store({ reader: cmptExcepStatisticsRequestReader, proxy: cmptExcepStatisticsRequestProxy }); //查询范围 开始时间 var startTimeCmptExcepStatistics = new Ext.form.DateField({ name: 'startTimeCmptExcepStatistics', fieldLabel: '开始时间', width: 150, maxLength: 20, minLength: 1, format: 'Y-m-d',//2010-01-01格式固定,y-m-d:10-01-01 readOnly: false, emptyText: nowDate, allowBlank: false, blankText: '请输入开始时间' }); //查询范围 结束时间 var endTimeCmptExcepStatistics = new Ext.form.DateField({ name: 'endTimeCmptExcepStatistics', fieldLabel: '结束时间', width: 150, maxLength: 20, minLength: 1, format: 'Y-m-d',//2010-01-01格式固定,y-m-d:10-01-01 readOnly: false, emptyText: nowDate, allowBlank: false, blankText: '请输入结束时间' }); //盘点异常统计 查询按钮定义 var btnSearchOfcmptExcepStatistics = new Ext.Button({ id: 'btnSearchOfcmptExcepStatistics', text: '盘点异常统计' }); //读取所有异常 cmptExcepStatisticsStore.load({ params: { startTime: "1900-01-01", endTime: "2999-01-01" } }); //btnSearchOfcmptExcepStatistics查询统计按钮 单击事件 btnSearchOfcmptExcepStatistics.on("click", function(){ var startTimeValue = startTimeCmptExcepStatistics.getValue(); var endTimeValue = endTimeCmptExcepStatistics.getValue(); //如果时间范围都选择的话 if (IsDateFieldNull(startTimeValue) && IsDateFieldNull(endTimeValue)) { var startTime = startTimeCmptExcepStatistics.formatDate(startTimeValue, 'yyyy-mm-dd'); var endTime = endTimeCmptExcepStatistics.formatDate(endTimeValue, 'yyyy-mm-dd'); cmptExcepStatisticsStore.load({ params: { startTime: startTime, endTime: endTime } }); } else { Ext.Msg.show({ title: '提示', msg: '请选择盘点统计时间范围!', buttons: Ext.Msg.OK, animEl: 'elId', width: 200, icon: Ext.MessageBox.QUESTION }); } }); //==盘点异常统计FormPanel==// var cmptExcepStatisticsStorePanel = new Ext.FormPanel({ width: 700, height: 400, title: '盘点异常统计', tbar: ["开始时间:", startTimeCmptExcepStatistics, " ", "结束时间:", endTimeCmptExcepStatistics, " ", btnSearchOfcmptExcepStatistics], items: { xtype: 'columnchart', store: cmptExcepStatisticsStore, xField: 'ID', //提示字符串 tipRenderer: function(chart, record, index, series){ if(series.yField == 'COUNT_EXCEPTION') return '盘点单ID:' + record.data.CHECK_ID + ' \n总异常数目: ' + record.data.COUNT_EXCEPTION + '\n盘点制定时间:' + record.data.CHECKPLAN_TIME+'\n盘点开始时间:' + record.data.BEGIN_TIME+'\n盘点结束时间:' + record.data.END_TIME; else if(series.yField == 'COUNT_CMPT_EXCEPTION') return '盘点单ID:' + record.data.CHECK_ID + ' \n部件异常数目: ' + record.data.COUNT_CMPT_EXCEPTION ; else if(series.yField == 'COUNT_STUFF_EXCEPTION') return '盘点单ID:' + record.data.CHECK_ID + ' \n耗材工具异常数目: ' + record.data.COUNT_STUFF_EXCEPTION ; }, xAxis: new Ext.chart.CategoryAxis({ title: '盘点单' }), yAxis: new Ext.chart.NumericAxis({ title: '异常数目' }), series: [{ type: 'column', displayName: '异常总数', yField: 'COUNT_EXCEPTION', style: { image:'bar.gif', mode: 'stretch' } },{ type:'line', displayName: '部件异常数', yField: 'COUNT_CMPT_EXCEPTION', style: { color: '#FFA928' } },{ type:'line', displayName: '耗材工具异常数', yField: 'COUNT_STUFF_EXCEPTION', style: { color: 0x15428B } }], extraStyle: { xAxis: { labelRotation: 0//x轴标题旋转度数 }, yAxis: { labelRotation: 0//y轴标题旋转度数 } } } }); // ===部件盘点异常统计Window===// var cmptExcepStatisticsRequestWindow = new Ext.Window({ name: 'cmptExcepStatisticsRequestWindow', title: '历史盘点异常统计', layout: 'fit', width: 600, height: 400, modal: true, closeAction: 'hide', resizable: false, items: [cmptExcepStatisticsStorePanel], listeners: { 'beforehide': function(){ cmptExcepStatisticsStorePanel.getForm().reset(); } } }); //==判断选择的时间范围是否为空==// function IsDateFieldNull(value){ if (value != null && value != "") { return true; } else { return false; } }
web层 URL获取数据代码
//=============================================================================== // Copyright (C) 2010 XXXX有限公司。版权所有。 //=============================================================================== // // 文件名:GetComponentsCheckExceptionStatistics.aspx.cs // // 文件描述:Url,部件盘点历史盘点异常数目统计 // // // 创建人: truman // 创建时间:2010年4月16日 // // 修改人: // 修改时间: // 修改描述: //=============================================================================== using System; using System.Data; using System.Configuration; using System.Collections; using System.Web; using System.Web.Security; using System.Web.UI; using System.Web.UI.WebControls; using System.Web.UI.WebControls.WebParts; using System.Web.UI.HtmlControls; using BusinessEntity.WarehouseItem.CheckWarehouse; namespace AfcMaintenanceSystem.Url.Warehouse.CheckWarehouse { public partial class GetComponentsCheckExceptionStatistics : System.Web.UI.Page { private BeCheckDetail beCheckDetail = new BeCheckDetail(); public string JSON = ""; protected void Page_Load(object sender, EventArgs e) { GetComponentsCheckExceptionStatisticsInfo(); } /// <summary> /// 获取统计部件历史盘点异常数目 /// </summary> public void GetComponentsCheckExceptionStatisticsInfo() { ////获得前台store传来的参数 //string limits = Request.Params["limit"]; //string starts = Request.Params["start"]; ////盘点单ID //string CHECK_ID = Request.Params["CHECK_ID"].ToString(); DateTime startTime = new DateTime(); DateTime endTime = new DateTime(); if (Request.Params["startTime"] != null && Request.Params["startTime"] != "")//""是为有参数,但无值,null是判断无此参数 { startTime = DateTime.Parse(Request.Params["startTime"].ToString()); } if (Request.Params["endTime"] != null && Request.Params["startTime"] != "") { endTime = DateTime.Parse(Request.Params["endTime"].ToString()); } //如果时间未赋值 0001-1-1 if (startTime.Year != 1 && endTime.Year != 1) { try { //获取从startTime到endTime之间的历史盘点异常数目 JSON = beCheckDetail.GetJsonComponentsCheckExceptionStatistics(startTime, endTime); } catch (Exception ex) { Response.Write("{success:false,errors:{info: '错误了,后台获取统计盘点异常数据!'}}"); throw (ex); } } else { Response.Write("{success:false,errors:{info: '没有选择统计盘点时间范围!'}}"); } } } }
业务层 源代码
/// <summary> /// 获得部件盘点异常统计 /// </summary> /// <param name="startTime">查询盘点范围 开始日期</param> /// <param name="endTime">查询盘点范围 结束日期</param> /// <returns></returns> public string GetJsonComponentsCheckExceptionStatistics(DateTime startTime, DateTime endTime) { string jsonString = ""; //Json字符串方法类 JSONHelper json = new JSONHelper(); json.Success = true; DataSet ds = null; int i = 1;//盘点单临时序号用 int countCmptException = 0; int countStuffException = 0; try { //获得盘点单历史异常记录 ds = Query(startTime, endTime); } catch (Exception ex) { throw (ex); } //将每一行的每一列的列名和对应的值放倒一个数组中,每一行以<BR>结束 foreach (DataRow dr in ds.Tables[0].Rows) { string CHECK_ID = dr["CHECK_ID"].ToString(); countCmptException = GetCount(" check_id = " + CHECK_ID + " and sequence_no is not null and store_amount != sys_amount ");//该盘点单所有异常 countStuffException = GetCount(" check_id = " + CHECK_ID + " and sequence_no is null and store_amount != sys_amount ");//该盘点单所有异常 json.AddItem("ID", i++);//盘点单临时序号 json.AddItem("CHECK_ID", CHECK_ID);//盘点单ID json.AddItem("COUNT_EXCEPTION",int.Parse(dr["COUNT_EXCEPTION"].ToString()));//盘点历史异常总记录数目 必须转换成整型,前台的chart表才能显示正确。 json.AddItem("COUNT_CMPT_EXCEPTION", countCmptException);//盘点历史异常部件记录数目 必须转换成整型,前台的chart表才能显示正确。 json.AddItem("COUNT_STUFF_EXCEPTION", countStuffException);//盘点历史异常耗材工具记录 必须转换成整型,前台的chart表才能显示正确。 if (dr["BEGIN_TIME"].ToString() != "") json.AddItem("BEGIN_TIME", ((DateTime)dr["BEGIN_TIME"]).ToString("yyyy-MM-dd"));//盘点开始时间 else json.AddItem("BEGIN_TIME", ""); if (dr["END_TIME"].ToString() != "") json.AddItem("END_TIME", ((DateTime)dr["END_TIME"]).ToString("yyyy-MM-dd"));//盘点结束时间 else json.AddItem("END_TIME", ""); if (dr["CHECKPLAN_TIME"].ToString() != "") json.AddItem("CHECKPLAN_TIME", ((DateTime)dr["CHECKPLAN_TIME"]).ToString("yyyy-MM-dd"));//盘点制定时间 else json.AddItem("CHECKPLAN_TIME", ""); json.ItemOk(); } //得到总记录数,用于分页页数 json.TotlalCount = ds.Tables[0].Rows.Count; jsonString = json.ToString(); return jsonString; }
暂未毕业,做点小项目,程序编的不是很完善,请大家原谅。
评论
2 楼
qimo601
2010-10-08
fengshengshijie 写道
非常实用,有个问题,chart中的"异常数目"能不能竖着展示,查了半天没找到
呵呵对不起,这是我以前实习时候做的项目,现在一直没研究这方面。。
你要是知道了,也可以告诉我一声。多谢
1 楼
fengshengshijie
2010-08-04
非常实用,有个问题,chart中的"异常数目"能不能竖着展示,查了半天没找到
发表评论
-
广告广告
2012-05-24 18:32 2盈创广告联盟 http://www.yo114.cn/ 成 ... -
php上传文件 报的错误 $_FILES[‘file’]['error']
2011-01-26 23:27 12868大家都知道,php上传文件后台报的错误$_FILES['fil ... -
虚拟空间中 php上传文件 突破限制
2011-01-26 22:45 872最近单位要求在外国一台服务器上布置一个php写的会议网站,服务 ... -
5步详解PHP文件上传功能的实现
2011-01-26 21:20 33261、表单部分允许用户上传文件,在HTML表单的声明中要加上一个 ... -
$_FILES[file]['error']
2011-01-25 14:40 2554$_FILES[file]['error']信息说明 ... -
PHP如何读写文件
2011-01-15 22:46 2753PHP如何读写文件PHP读写文件,就如同ASP中使用FSO进行 ... -
Extjs chart 总结 reload-chart.js 修改
2010-04-17 13:04 7419最近用到 Extjs自带的 rel ... -
grid.getSelectionModel的所有操作
2010-04-12 11:32 28681. var model = grid.getSelectio ... -
Extjs中的组件含有ID,会导致界面混乱。(textfield,comboBox等)
2010-04-01 14:28 3935我的代码中的一些控件开始都有ID,在我新打开一些窗口的时候,总 ... -
Extjs 从grid中导出Excel表格。后台为C#(绝对好用)
2010-03-31 15:40 8273一、在程序中增加附件中js文件的引用: 二、定义一个导出Ex ... -
用css控制背景图片的位置,大小
2009-03-20 16:05 38917引用连接:http://hi.baidu. ...
相关推荐
EXTJS 折线 chart action 代码示例 1.远程加载数据(两种方法) 2.本地加载数据 3.完整示例,实例 4.后台为JAVA代码
Extjs4.2 Chart柱状图实例。
extjs chart highchart hede hodo
简化版,仅包含的Test.js 博文链接:https://atian25.iteye.com/blog/432513
sencha官网中ext4中关于曲线图的内容!!!!!
完整源码 博文链接:https://atian25.iteye.com/blog/433882
经过一周的时间终于做出来了,此文件代码主要的是实现动态切换 chart line ,tips 显示数据的饼状图和grids,难点在作用域的实现需要的有一定的js基础,(因开发的原因后台代码未上传,基于json的传输,SQL是...
Extjs4 中Line chart使用Ajax数据源绘图,具体请参考文章http://blog.csdn.net/cl11404303/archive/2011/05/31/6457951.aspx
支持富客户端extjs技术 绚丽的报表图形
ExtJS效果Tabs形式
Ext.ux.GoogleChart extjs插件Ext.ux.GoogleChart extjs插件
Extjs 批量上传图片,选择多个图片可批量删除操作,
extjs的数据传递
100多个ExtJS应用初学实例集,采用最新框架实现。
EXTJS应用EXTJS应用EXTJS应用EXTJS应用EXTJS应用EXTJS应用
extjs资料extjs资料extjs资料extjs资料extjs资料
多版本整合ExtJs应用多版本整合ExtJs应用多版本整合ExtJs应用多版本整合ExtJs应用多版本整合ExtJs应用多版本整合ExtJs应用多版本整合ExtJs应用多版本整合ExtJs应用多版本整合ExtJs应用多版本整合ExtJs应用。
用Ext编写的多文件上传组件,已封装。 支持多文件上传,文件下载,文件删除,
javascript 写的 用于在客户端创建丰富多彩的 web 应用程序界面 ExtJS 可以用来开发 RIA Rich Internet Application 富互联网应用系统 的 开源 AJAX 应用框架 使用的开源协 议是 GPL ExtJS 是一个用 javascript 写...