JS(十四)导出excel
来源:互联网 发布:网站源码修改工具 编辑:程序博客网 时间:2024/06/06 09:39
/** * 点击导出excel-------------------------start------------------------------ */var idTmr;function getExplorer() {var explorer = window.navigator.userAgent;// ieif (explorer.indexOf("MSIE") >= 0) {return 'ie';}// firefoxelse if (explorer.indexOf("Firefox") >= 0) {return 'Firefox';}// Chromeelse if (explorer.indexOf("Chrome") >= 0) {return 'Chrome';}// Operaelse if (explorer.indexOf("Opera") >= 0) {return 'Opera';}// Safarielse if (explorer.indexOf("Safari") >= 0) {return 'Safari';}}function exportExcel() {// 整个表格拷贝到EXCEL中if (getExplorer() == 'ie') {var curTbl = document.getElementById("tablec");var oXL = new ActiveXObject("Excel.Application");// 创建AX对象excelvar oWB = oXL.Workbooks.Add();// 获取workbook对象var xlsheet = oWB.Worksheets(1);// 激活当前sheetvar sel = document.body.createTextRange();sel.moveToElementText(curTbl);// 把表格中的内容移到TextRange中sel.select();// 全选TextRange中内容sel.execCommand("Copy");// 复制TextRange中内容xlsheet.Paste();// 粘贴到活动的EXCEL中oXL.Visible = true;// 设置excel可见属性try {var fname = oXL.Application.GetSaveAsFilename("Excel.xls","Excel Spreadsheets (*.xls), *.xls");} catch (e) {print("Nested catch caught " + e);} finally {oWB.SaveAs(fname);oWB.Close(savechanges = false);// xls.visible = false;oXL.Quit();oXL = null;// 结束excel进程,退出完成// window.setInterval("Cleanup();",1);idTmr = window.setInterval("Cleanup();", 1);}} else {tableToExcel("tablec")}}function Cleanup() {window.clearInterval(idTmr);CollectGarbage();}var tableToExcel = (function() { var uri = 'data:application/vnd.ms-excel;base64,', 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"><meta http-equiv="Content-Type" charset=utf-8"><head><!--[if gte mso 9]><xml><x:ExcelWorkbook><x:ExcelWorksheets><x:ExcelWorksheet><x:Name>{worksheet}</x:Name><x:WorksheetOptions><x:DisplayGridlines/></x:WorksheetOptions></x:ExcelWorksheet></x:ExcelWorksheets></x:ExcelWorkbook></xml><![endif]--></head><body><table>{table}</table></body></html>', base64 = function(s) { return window.btoa(unescape(encodeURIComponent(s))) }, format = function(s, c) { return s.replace(/{(\w+)}/g, function(m, p) { return c[p]; }) } return function(table, name) { if (!table.nodeType) table = document.getElementById(table) var ctx = {worksheet: name || 'Worksheet', table: table.innerHTML} window.location.href = uri + base64(format(template, ctx)) }})()/** * 点击导出excel-------------------------end------------------------------ */
用法:
1、在加粗部分是要导出表格的id;
2、表格必须提前填充好;
3、exportExcel()函数绑定到导出按钮。
阅读全文
0 0
- JS(十四)导出excel
- js导出EXCEL js导出EXCEL
- JS导出datagrid导出Excel
- 纯JS导出excel(支持中文)
- JS导出EXCEL
- js导出到excel
- js导出Excel
- js导入导出excel
- js导出Excel
- js 导出 excel
- js 导出Excel
- JS导出Excel/word
- JS 导出EXCEL
- js导出Excel
- JS导出Excel
- Js导出Excel
- js操作Excel导出
- JS导出 excel
- python入门(四):循环( for in 和 while)
- Java设计模式单例模式
- 【技术】OpenCV入门:3.1.0版本中的imread()函数flag参数
- 王师傅教我的单调栈
- 最长回文子串
- JS(十四)导出excel
- Angular 中间部分 2.2 依赖注入和Http
- java之用volatile和不用volatile的区别
- 【华为机试】iNOC产品部-杨辉三角的变形
- 以太坊的公链支持挖到空的区块
- jQuery的选择器中的通配符[id^='code']
- 阿里云高性能时序数据库 HiTSDB 启动公测_为物联网而生的数据库!
- MySQL架构设计谈:从开发规范、选型、拆分到减压(二)
- JavaWeb学习总结(十二)——使用Session防止表单重复提交