JS下载EXT中指定grid中的数据到EXCEL中
2009-03-13 09:33
351 查看
传递要下载数据所在的grid给下面的函数,即可实现.
如果只需要下载视图中的某几列,则请将不需要的列隐藏.
隐藏必须要设置{dataIndex:'...',header:'...',sortable:true}
此代码仍可修改,做到只下载选中的记录,而不是当前视图中的所有数据.
修改相关说明(selModel为CheckboxSelectionModel):
var obj = grid.getSelectionModel().getSelections(); //选中的记录
var l = obj.length; //选中的记录数
//i为列的下标
//n为记录行
obj
.get(cm.getDataIndex(i)); //选中的第n条记录的第i列值
//---------------------------------------------------------------
//下载指定视图中的数据到EXCEL中
function downloadViewData(grid)
{
try {
var xls = new ActiveXObject ("Excel.Application");
}
catch(e) {
alert( "要打印该表,您必须安装Excel电子表格软件,同时浏览器须使用“ActiveX 控件”,您的浏览器须允许执行控件。 请点击【帮助】了解浏览器设置方法!");
return "";
}
xls.visible =true; //设置excel为可见
var xlBook = xls.Workbooks.Add;
var xlSheet = xlBook.Worksheets(1);
var cm = grid.getColumnModel();
var colCount = cm.getColumnCount();
var temp_obj = [];
//只下载没有隐藏的列(isHidden()为true表示隐藏,其他都为显示)
//临时数组,存放所有当前显示列的下标
for(i=0;i<colCount;i++){
if(cm.isHidden(i) == true){
}else{
temp_obj.push(i);
}
}
for(i=1;i<=temp_obj.length;i++){
//显示列的列标题
xlSheet.Cells(1,i).Value = cm.getColumnHeader(temp_obj[i - 1]);
}
var store = grid.getStore();
var recordCount = store.getCount();
var view = grid.getView();
for(i=1;i<=recordCount;i++){
for(j=1;j<=temp_obj.length;j++){
//EXCEL数据从第二行开始,故row = i + 1;
xlSheet.Cells(i + 1,j).Value = view.getCell(i - 1,temp_obj[j - 1]).innerText;
}
}
xlSheet.Columns.AutoFit;
xls.ActiveWindow.Zoom = 75
xls.UserControl = true; //很重要,不能省略,不然会出问题 意思是excel交由用户控制
xls=null;
xlBook=null;
xlSheet=null;
}
如果只需要下载视图中的某几列,则请将不需要的列隐藏.
隐藏必须要设置{dataIndex:'...',header:'...',sortable:true}
此代码仍可修改,做到只下载选中的记录,而不是当前视图中的所有数据.
修改相关说明(selModel为CheckboxSelectionModel):
var obj = grid.getSelectionModel().getSelections(); //选中的记录
var l = obj.length; //选中的记录数
//i为列的下标
//n为记录行
obj
.get(cm.getDataIndex(i)); //选中的第n条记录的第i列值
//---------------------------------------------------------------
//下载指定视图中的数据到EXCEL中
function downloadViewData(grid)
{
try {
var xls = new ActiveXObject ("Excel.Application");
}
catch(e) {
alert( "要打印该表,您必须安装Excel电子表格软件,同时浏览器须使用“ActiveX 控件”,您的浏览器须允许执行控件。 请点击【帮助】了解浏览器设置方法!");
return "";
}
xls.visible =true; //设置excel为可见
var xlBook = xls.Workbooks.Add;
var xlSheet = xlBook.Worksheets(1);
var cm = grid.getColumnModel();
var colCount = cm.getColumnCount();
var temp_obj = [];
//只下载没有隐藏的列(isHidden()为true表示隐藏,其他都为显示)
//临时数组,存放所有当前显示列的下标
for(i=0;i<colCount;i++){
if(cm.isHidden(i) == true){
}else{
temp_obj.push(i);
}
}
for(i=1;i<=temp_obj.length;i++){
//显示列的列标题
xlSheet.Cells(1,i).Value = cm.getColumnHeader(temp_obj[i - 1]);
}
var store = grid.getStore();
var recordCount = store.getCount();
var view = grid.getView();
for(i=1;i<=recordCount;i++){
for(j=1;j<=temp_obj.length;j++){
//EXCEL数据从第二行开始,故row = i + 1;
xlSheet.Cells(i + 1,j).Value = view.getCell(i - 1,temp_obj[j - 1]).innerText;
}
}
xlSheet.Columns.AutoFit;
xls.ActiveWindow.Zoom = 75
xls.UserControl = true; //很重要,不能省略,不然会出问题 意思是excel交由用户控制
xls=null;
xlBook=null;
xlSheet=null;
}
相关文章推荐
- HTML页面调用JS代码将JSON数据导入到Excel表中,并下载 实例
- js实现数据的excel下载
- Ext本地数据在Grid中分页显示,隐藏指定字段
- Ext JS GridPanel + WebService + 返回xml数据 + 批量删除
- node.js读取Excel数据(下载图片)的方法示例
- Ext.net1.0之GridPanel数据导出Excel
- js读取Excel文件数据-IE浏览器
- SSH+Ext左侧tree右侧grid,点击左侧tree节点右侧grid数据动态加载和分页问题
- datagrid数据导出到excel文件给客户端下载的几种方法
- js导出table数据到excel即导出为EXCEL文档的方法
- Ext JS GridPanel + Sqllite + 查询分页
- JSP实现从数据库导出数据到Excel下载的方法
- ie浏览器用js读取excel数据
- 从Infragistics UltraWebGrid 导出数据到 Excel 序列
- Ext.Net 1.x_Ext.Net.GridPanel之导出EXCEL
- 从Excel表格拖放数据到Ext Grid中
- js中使用DOM复制(克隆)指定节点名数据到新的XML文件中的代码
- Ext中Grid得到选择行数据的方法总结
- js EXT : Ext.grid.GridPanel viewConfig
- winform导出dataviewgrid数据为excel的方法