EasyUI 如何结合JS导出Excel文件

本文介绍如何使用JavaScript结合EasyUI的DataGrid组件实现数据导出到Excel的功能。核心方法涉及利用ActiveX对象操作Excel,包括设置表头、填充数据等步骤。

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

废话俺就少说了,直接进入正题!!单纯的JS能够导出Excel的不多见,一般都需要调用客户端所安装的Office Excel组件来完成这个工作。这里我主要讲EasyUI内的DataGrid如何结合JS导出Excel文件

一、 导出Excel的核心代码段如下所示

function Exproter() {  
            //获取Datagride的列  
            var rows = $('#test').datagrid('getRows');  
            var oXL = new ActiveXObject("Excel.Application"); //创建AX对象excel   
            var oWB = oXL.Workbooks.Add(); //获取workbook对象   
            var oSheet = oWB.ActiveSheet; //激活当前sheet  
            for (var i = 0; i < rows.length; i++) {  
                oSheet.Cells(i + 1, 1).value = rows[i].O_NAME;  
            }  
            oXL.Visible = true; //设置excel可见属性  
}  

二、以上JS方法能够顺利执行的大前提就是

1.机器上Excel已经安装.

2.Internet 选项=>安全=>Internet 

\"对没有标记为安全的ActiveX控件进行初始化和脚本运行,设定为启用\"


转载自:http://www.stepday.com/topic/?247

//EasyUI datagrid 动态导出Excel  
function ExporterExcel() {  
            //获取Datagride的列  
            var rows = $('#tt').datagrid('getRows');  
            var columns = $("#tt").datagrid("options").columns[0];  
            var oXL = new ActiveXObject("Excel.Application"); //创建AX对象excel   
            var oWB = oXL.Workbooks.Add(); //获取workbook对象   
            var oSheet = oWB.ActiveSheet; //激活当前sheet  
            //设置工作薄名称  
            oSheet.name = "导出Excel报表";  
            //设置表头  
            for (var i = 0; i < columns.length; i++) {  
                oSheet.Cells(1, i+1).value = columns[i].title;  
            }  
            //设置内容部分  
            for (var i = 0; i < rows.length; i++) {  
                //动态获取每一行每一列的数据值  
                for (var j = 0; j < columns.length; j++) {                 
                    oSheet.Cells(i + 2, j+1).value = rows[i][columns[j].field];  
                }     
            }                
            oXL.Visible = true; //设置excel可见属性  
}  



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值