EXT JS把gridPanel数据导入到EXCEL

实现代码
function downloadViewData(grid) {//grid是所要导出的grid表格
try {
var xls = new ActiveXObject("Excel.Application");
} catch (e) {
alert("要打印该表,您必须安装Excel电子表格软件,同时浏览器须使用“ActiveX 控件”,您的浏览器须允许执行控件。 请点击【帮助】了解浏览器设置方法!");
return "";  
}
var cm = grid.getColumnModel();
   	 var colCount = cm.getColumnCount();   
   	 //alert('总列数:'+colCount);
   	 xls.visible = true; // 设置excel为可见
   	 var xlBook = xls.Workbooks.Add;
   	 var xlSheet = xlBook.Worksheets(1);    
   	 var temp_obj = [];
   	 // 只下载没有隐藏的列(isHidden()为true表示隐藏,其他都为显示)    
   	 for (i = 1; i < colCount; i++) {
    	 if (cm.isHidden(i) == true) {
    	 } else {
     	 temp_obj.push(i);   
     	 }
   	 }
   	 for (l = 1; l <= temp_obj.length; l++) {
    	 xlSheet.Cells(1, l).Value = cm.getColumnHeader(temp_obj[l-1]); 
   	 }
    	 var store = grid.getStore();
   	 var recordCount = store.getCount();
   	 //alert("记录总数:"+recordCount);
   	 //alert('总列数:'+temp_obj.length);
   	 var view = grid.getView();
   	 for (k = 1; k <= recordCount; k++) {
   	 //alert('k-'+k);
    	 for (j = 1; j <= temp_obj.length; j++) {
     	 // EXCEL数据从第二行开始,故row = k + 1;
    	 //alert(view.getCell(k - 1, temp_obj[j- 1]).innerText);
     	 xlSheet.Cells(k + 1, j).Value = view.getCell(k - 1, temp_obj[j- 1]).innerText; 
     	 }
   
}
xlSheet.Columns.AutoFit;
   	 xls.ActiveWindow.Zoom = 75;
   	 xls.UserControl = true; // 很重要,不能省略,不然会出问题 意思是excel交由用户控制
   	 xls = null;
   	 xlBook = null;
   	 xlSheet = null;
   
}


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值