贴代码,一切尽在注释中
<html>
<head>
<meta charset="utf-8">
</head>
<body>
<input type="button" value="下载设备模板" onclick="foo;" />
<script type="text/javascript" language="javascript">
var downloadTemplate = function
{
/** * 根据所给数据创建并返回单行 tr节点 * data (必选), tag (可选, 标识创建的节点类型) **/
var getTr=function(data,tag)
{
var tr=document.createElement("tr"); for(var i=0;i<data.length;i++)
{
var item=document.createElement(tag||"td"); item.innerHTML=data[i]; tr.appendChild(item);
}
return tr;
}
; /** * 根据所给数据创建并返回 table节点 * data (可选,无则返回空的table节点), head(可选, 标识是否存在表头) **/
var getTable=function(data,head)
{
var table=document.createElement("table");
var head=head||false; //存在表头设标识为th,否则为td
var tag=head?"th":"td"; //判断是一维||二维,执行不同逻辑
if(data[0] instanceof Array)
{
for(var i=0;i<data.length;i++)
{
//第一行数据根据tag创建节点类型
(i==0)?table.appendChild(getTr(data[i],tag)):table.appendChild(getTr(data[i]));
}
}
else if(data instanceof Array)
table.appendChild(getTr(data,tag));
return table;
}
; /** * table (必选, table节点) * uri 为生成excel的头部标签 * xmlns xml命名空间 * 返回xls资源 **/
var getXls=function(table)
{
var uri = 'data:application/vnd.ms-excel;base64,';
var template = '<html xmlns:o="urn:schemas-microsoft-com:office:office" '+ 'xmlns:x="urn:schemas-microsoft-com:office:excel" '+ 'xmlns="http://www.w3.org/TR/REC-html40">'+ '<head>'+ '<!--[if gte mso 9]>'+ '<xml>'+ '<x:ExcelWorkbook>'+ '<x:ExcelWorksheets>'+ '<x:ExcelWorksheet>'+ '<x:WorksheetOptions>'+ '<x:DisplayGridlines/>'+ '</x:WorksheetOptions>'+ '</x:ExcelWorksheet>'+ '</x:ExcelWorksheets>'+ '</x:ExcelWorkbook>'+ '</xml>'+ '<![endif]-->'+ '</head>'+ '<body>'+ '<table>{table}</table>'+ '</body>'+ '</html>';
/** * 转码 base 64 * window.btoa能从ascii/二进制流中创建一个base64编码的字符串 * escape编码 unescape 解码字符串 * encodeURIComponent编码 DecodeURIComponent 解码字符串 **/
var base64 = function(s)
{
return window.btoa(unescape(encodeURIComponent(s)));
};
//返回替换完具体数据的xls模板 var getXlsXml = function(template,data)
{
return template.replace(/{(\w+)}/g,data);
};
//返回资源链接
return uri+base64(getXlsXml(template, table.innerHTML));
};
/** * IE浏览器 * 使用Microsoft ActiveXObject组件生成xls ( 只兼容IE浏览器,选择允许加载组件 ) * table(必选, table节点) **/
var msDownload=function(data)
{
var xls = new ActiveXObject("Excel.Application");
xls.visible = true;
var xlsBook = xls.Workbooks.Add;
var xlsheet = xlsBook.Worksheets(1);
for(var i=0;i<data.length;i++)
if(data[0] instanceof Array)
for(var j=0;j<data[0].length;j++)
xlsheet.Cells(i+1,j+1).Value=data[i][j]; else xlsheet.Cells(1,i+1).Value=data[i]; //用完释放 xls=null; };
//参数: data(必选,一维||二维 数组), head(可选, 标识是否存在表头)
var download=function(data , head)
{
if(window.navigator.userAgent.indexOf("MSIE") >= 0)
msDownload(data);
else //下载(RestFul:资源下载置于超链接,地址为资源定位地址)
window.location.href =getXls(getTable(data,head));
};
return
{
getXls:getXls, msDownload:msDownload, download:download
};
};
//测试数据 var od=['aid','pwd','设备名称','网关DK','区域'];
var td=[ ['aid','pwd','设备名称','网关DK','区域'], ['10086','root','松下R-399','208564165456542','2 #201'], ['10001','root','索尼SUV 09','456542895564165','2 #201'] ];
var foo=function
{
// new downloadTemplate.download(od,true);
new downloadTemplate.download(td,true);
}
;
</script>
</body>
</html>
测试结果:
在IE浏览器上需要允许加载ActiveX控件,之后在弹出的对话框中点击"是"
下载下来的表格如下:
chrome:
打开表格:
以上所述是小编给大家介绍的JavaScript生成.xls文件的代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
# js生成xls文件
# jsp实现从服务器下载xls文件到客户端的方法
# 如何解决在jsp页面上导入.xls文件报错问题
# 可选
# 小编
# 是否存在
# 所给
# 加载
# 在此
# 索尼
# 给大家
# 尽在
# 则为
# 所述
# 用完
# 创建一个
# 给我留言
# 感谢大家
# 超链接
# 疑问请
# 有任何
# 器上
# 测试数据
相关文章:
南平网站制作公司,2025年南平市事业单位报名时间?
免费ppt制作网站,有没有值得推荐的免费PPT网站?
赚钱网站制作软件,建一个网站怎样才能赚钱?是如何盈利的?
如何通过商城自助建站源码实现零基础高效建站?
头像制作网站在线制作软件,dw网页背景图像怎么设置?
建站主机类型有哪些?如何正确选型
婚礼视频制作网站,学习*后期制作的网站有哪些?
陕西网站制作公司有哪些,陕西凌云电器有限公司官网?
如何获取免费开源的自助建站系统源码?
如何在阿里云ECS服务器部署织梦CMS网站?
如何在IIS管理器中快速创建并配置网站?
小型网站建站如何选择虚拟主机?
无锡营销型网站制作公司,无锡网选车牌流程?
网站制作费用多少钱,一个网站的运营,需要哪些费用?
如何用IIS7快速搭建并优化网站站点?
建站主机功能解析:服务器选择与快速搭建指南
临沂网站制作公司有哪些,临沂第四中学官网?
如何通过商城免费建站系统源码自定义网站主题?
全景视频制作网站有哪些,全景图怎么做成网页?
Android滚轮选择时间控件使用详解
学校建站服务器如何选型才能满足性能需求?
建站168自助建站系统:快速模板定制与SEO优化指南
北京制作网站的公司,北京铁路集团官方网站?
香港服务器租用费用高吗?如何避免常见误区?
建站之星后台搭建步骤解析:模板选择与产品管理实操指南
已有域名建站全流程解析:网站搭建步骤与建站工具选择
太原网站制作公司有哪些,网约车营运证查询官网?
Python lxml的etree和ElementTree有什么区别
宿州网站制作公司兴策,安徽省低保查询网站?
建站VPS推荐:2025年高性能服务器配置指南
建站VPS能否同时实现高效与安全翻墙?
网站制作话术技巧,网站推广做的好怎么话术?
如何构建满足综合性能需求的优质建站方案?
动图在线制作网站有哪些,滑动动图图集怎么做?
韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐
活动邀请函制作网站有哪些,活动邀请函文案?
手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?
大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?
如何在IIS中配置站点IP、端口及主机头?
建站之星24小时客服电话如何获取?
整人网站在线制作软件,整蛊网站退不出去必须要打我是白痴才能出去?
建站主机如何安装配置?新手必看操作指南
C++用Dijkstra(迪杰斯特拉)算法求最短路径
网站制作新手教程,新手建设一个网站需要注意些什么?
如何在云虚拟主机上快速搭建个人网站?
php能控制zigbee模块吗_php通过串口与cc2530 zigbee通信【介绍】
建站之星导航如何优化提升用户体验?
如何通过建站之星自助学习解决操作问题?
清单制作人网站有哪些,近日“兴风作浪的姑奶奶”引起很多人的关注这是什么事情?
如何在阿里云虚拟主机上快速搭建个人网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。