EXTJS4X的Grid导出Excel

本文介绍了一种方法将EXTJS4X的Grid数据导出为Excel文件,涉及使用ActiveXObject操作Excel,包括创建新Excel,保存表格,设置页面布局,以及对单元格的各种操作,如内容、样式和边框等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在网上参考了以为大神的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



1.创建一个新<

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值