首先定义如下JS文件:
/*
*功能:直接由Ext的grid生成Excel
*注意: 只支持IE
*参数:param1: gridId
* param2: sheetName
*/
Ext.downExcel= function(config){
//Ext.Excel.superclass.constructor.call(this, config);
Ext.apply(this,config);
};
Ext.apply(Ext.downExcel.prototype,{
extGridToExcel : function(){
try{
if(Ext.getCmp(this.gridId)){
/********************************************* grid 生成 Excel ***************************************/
var oXL = new ActiveXObject("Excel.Application");
var oWB = oXL.Workbooks.Add();
var oSheet = oWB.ActiveSheet;
var grid = Ext.getCmp(this.gridId);
var store = grid.getStore();
var recordCount = store.getCount();
var view = grid.getView();
var cm = grid.getColumnModel();
var colCount = cm.getColumnCount();
var temp_obj = [];
for(var i = 0; i < colCount;i++){
if(cm.isHidden(i)){
}else{
temp_obj.push(i);
}
}
for(var i = 1; i <= temp_obj.length;i++){
oSheet.Cells(1,i).value = cm.getColumnHeader(temp_obj[i - 1]);
}
for(var i = 1 ; i <= recordCount; i++){
for(var j = 1; j<= temp_obj.length; j++){
oSheet.Cells(i+1,j).value = view.getCell(i-1,temp_obj[j-1]).innerText;
}
}
if(this.sheetName){
oSheet.Name = this.sheetName;
}
oXL.UserControl = true;
oXL.Visible = true;
}else{
Ext.Msg.alert('Error','明细数据grid没有创建成功!');
return;
}
}catch(e){
if(Ext){
Ext.Msg.show({
title:'提示',
msg:'请设置IE的菜单\'工具\'->Internet选项->安全->自定义级别->\'对未标记为可安全执行脚本ActiveX控件初始化并执行脚本\'->选择[启用] 就可以生成Excel',
buttons:Ext.Msg.OK,
icon:Ext.Msg.INFO
});
}else{
alert('不支持ExtJs框架');
return;
}
}
}
});
调用:
buttons:[{ text:'导出Excel',
handler:function() {
var excel = new Ext.Excel({gridId:'datagrid',sheetName:'中期生产计划--逆排'});
excel.extGridToExcel();
}
}]
没上传 调用代码
那几行 自己打上吧
用起来 真爽啊~~~~
分享到:
相关推荐
将页面的GridPanel中的数据导出到Excel中 测试Ext:版本2.2.1 支持GridSummary,GroupSummary和GroupHeaderPlugin插件 使用方法: 1)把三个JS文件引入到页面中 2)调用例句: var data2Excel = new Ext.icss.Data2...
该例子实现了ext的gridpanel多层表头+分组+小计以及与Java后台交互的全代码。还有自适应浏览器大小的功能包括导出excel,里面有注释,可能注释不全。分别为group.jsp,totals.jsp页面。
`Ext`是一个流行的JavaScript框架,它提供了一种强大的方式来构建富客户端应用程序,而将Ext应用中的数据导出到Excel则可以方便用户进行进一步的数据处理和分析。 `Ext`框架的核心是它的组件模型,其中包括各种图表...
根据给定的信息,本文将详细解释如何在Ext框架中实现Excel导出功能。这涉及到从前台界面设计到后端数据处理的多个环节。下面将依次介绍相关知识点。 ### 一、Ext简介 Ext是一个用于构建交互式Web应用程序的...
以上就是利用Ext4.1.1a的GridPanel导出数据到Excel的基本流程。实际应用中,可能还需要考虑其他因素,比如数据过滤、排序状态的保持,以及用户界面的反馈等。对于大型数据集,可能还需要优化性能,避免一次性加载...
以下是一个简单的EXTJS4导出Excel的代码示例: ```javascript // 假设你已经有了一个名为grid的GridPanel实例,其store为store实例 var csvData = ''; store.each(function(record) { var fields = record.data; ...
"Ext 完整例子(含Excel导出)"这个资源显然是一个包含完整的Ext应用程序示例,特别强调了支持Excel数据导出的功能。这通常涉及到在Web应用中集成数据处理和文件生成的能力。 首先,我们要理解Ext的核心概念。它基于...
在"Ext增删改查和excel导出"这个主题中,我们将探讨如何在ExtJS应用中实现数据的CRUD操作(创建、读取、更新、删除)以及如何将数据导出为Excel格式。 1. 创建(Create) 在ExtJS中,可以使用GridPanel或FormPanel...
var grid = new Ext.grid.GridPanel({ width: 600, height: 400, cm: columnModel, store: store }); ``` 3. **数据导出**:EXTJS3并没有内置直接将Grid数据导出到Excel的功能,但我们可以通过模拟浏览器的下载...
完成上述步骤后,还需要对导出功能进行调试,确保导出的数据格式正确,并且能够被Excel软件正常打开和显示。此外,还可以根据实际需求添加更多的优化措施,比如增加进度提示、错误处理等。 通过上述步骤,我们成功...
我们可以通过Ext.getcmp()方法获取到GridPanel对象并通过重写的方法获取Excel字符串具体方法可以百度到。这个应该也不是什么大问题。 代码如下: //输出报表 function ExportReport(title) { var vExportContent = ...
尽管EXTJS GridPanel功能强大,但也有其局限性,比如在EXTJS 2.02版本中可能不支持列锁定和默认的统计功能,也不直接支持数据导出为Excel或PDF格式。然而,随着EXTJS版本的迭代,这些问题在后续版本中得到了改进。 ...
比如,EXT 2.0版本不支持列锁定,没有默认的统计功能,也不能直接导出为Excel或PDF格式。这些限制可能需要开发者额外编写代码或者寻找其他库来补充。 EXT表格控件的使用涉及到许多配置和交互细节,包括但不限于以下...
2. **导出到 PDF 或 Excel**:可以使用第三方库或者 ExtJS 的扩展库将数据网格的内容导出为 PDF 或 Excel 文件,再通过这些文件进行打印。 #### 三、案例分析 本案例中的代码展示了如何使用 ExtJS 实现一个基本的...
5. **GRID框架与库**:在实际开发中,常见的GRID解决方案有Ext JS的GridPanel、jQuery UI的DataTables、AngularJS的UI-Grid等。这些库提供了丰富的API和配置选项,简化了开发流程,同时也提供了诸如拖放排序、行编辑...