实现代码
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;
}
EXT JS把gridPanel数据导入到EXCEL
最新推荐文章于 2017-08-11 16:50:38 发布