在网上参考了以为大神的EXT4以前版本的进行了修改
function downloadViewData(grid) {//grid是所要导出的grid表格
alert("进入真正的方法");try {
var xls = new ActiveXObject("Excel.Application");
} catch (e) {
alert("要打印该表,您必须安装Excel电子表格软件,同时浏览器须使用“ActiveX 控件”,您的浏览器须允许执行控件。 请点击【帮助】了解浏览器设置方法!");
return "";
}
var cm = grid.columns;
var colCount = cm.length;
// alert('总列数:'+colCount);
var selected = grid.getSelectionModel().getSelection();
var xlBook = xls.Workbooks.Add;
var xlSheet = xlBook.Worksheets(1);
var temp_obj = [];
// 只下载没有隐藏的列(isHidden()为true表示隐藏,其他都为显示)
alert(cm[0].hidden);
alert(cm[0].hidden == false);
for (var i = 1; i < colCount; i++) {
if (cm[i].hidden == false) {
temp_obj.push(i);
}
}
xls.Range("A1",xls.Cells(1, temp_obj.length)).MergeCells = true;
xlSheet.Cells(1, 1).Value = "我最帅";
xlSheet.Cells(1, 1).Font.Size = 10;
xlSheet.Cells(1, 1).Font.Bold = true;
xlSheet.Cells(1, 1).HorizontalAlignment= 3;
xlSheet.Cells(1, 1).Interior.Pattern = 2;
for (var l = 1; l <= temp_obj.length; l++) {
xlSheet.Cells(2, l).Value = cm[temp_obj[l-1]].text;
}
var store = grid.getStore();
var recordCount = store.getCount();
// alert("记录总数:"+recordCount);
// alert('总列数:'+temp_obj.length);
if(selected.length < 1){
for (var k = 1; k <= recordCount; k++) {
//alert('k-'+k);
model = store.getAt(k-1);
for (var j = 1; j <= temp_obj.length; j++) {
var name = cm[j].dataIndex;
var value = model.get(name);
xlSheet.Cells(k + 2, j).Value = value;
}
}
}else{
for (var k = 1; k <= selected.length; k++) {
//alert('k-'+k);
model = selected[k-1];
for (var j = 1; j <= temp_obj.length; j++) {
var name = cm[j].dataIndex;
var value = model.get(name);
xlSheet.Cells(k + 2, j).Value = value;
}
}
}
alert("cell赋值结束");
xls.visible = true; // 设置excel为可见
xlSheet.Columns.AutoFit;
xls.ActiveWindow.Zoom = 75;
xls.UserControl = true; // 很重要,不能省略,不然会出问题 意思是excel交由用户控制
xls = null;
xlBook = null;
xlSheet = null;
};
下面是转载的一位大神JS操作EXCEL的重用方法
http://www.cnblogs.com/askyes/archive/2011/08/16/2141490.html