Ext 将grid中的数据导出到Excel和打印出来 Ext 将grid中的数据导出到Excel和打印出来 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 http://blog.csdn.net/zoujp_xyz/archive/2011/04/26/6364886.aspxhttp://blog.csdn.net/zoujp_xyz/archive/2011/04/26/6364943.aspx //公用下载Grid到Execl方法 shawn 2011-02-28 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 || cm.getColumnHeader(i) == '<div class="x-grid3-hd-checker"> </div>') { //不下载CheckBox列和隐藏列 } 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 = 100 xls.UserControl = true; //很重要,不能省略,不然会出问题 意思是excel交由用户控制 xls = null; xlBook = null; xlSheet = null; } http://blog.csdn.net/zoujp_xyz/archive/2011/05/17/6426231.aspx 有没有办法通过下标去取json对象里面的值 如何用getElementById调用JS代码 问一个应该不是很难的问题。 提示错误'imgmore.style'为空或不是对象,怎么回事?~~~急!!! 一段有趣的代码,请大家进来看看. 谁有取图片尺寸的JS的代码?谢谢了 急!!!我在页面字符集是gb2312时能调用外部js文件,但在utf-8时就不调用了,这是为什么? 求生日提示的代码~~~ 如何调用Td里的hidden值?急急急!!! 给切换的按钮下的模块动态添加内容,为什么重复呢 css如何实现文章分栏,控制字距,行距? 鼠标停在链接上,如何弹出页面预览
http://blog.csdn.net/zoujp_xyz/archive/2011/04/26/6364943.aspx
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 || cm.getColumnHeader(i) == '<div class="x-grid3-hd-checker"> </div>') { //不下载CheckBox列和隐藏列
} 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 = 100
xls.UserControl = true; //很重要,不能省略,不然会出问题 意思是excel交由用户控制
xls = null;
xlBook = null;
xlSheet = null;
}