最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

前端js打印(导出)excel表格的方法实例

来源:动视网 责编:小采 时间:2020-11-27 20:01:47
文档

前端js打印(导出)excel表格的方法实例

前端js打印(导出)excel表格的方法实例:本文主要和大家分享前端js打印(导出)excel表格的方法实例,希望能帮助到大家。产品原型:图片.png功能需求:点击导出考勤表格按钮,会自动下载成Excel格式图片.png图片.pngjsp页面代码:<p class="tools"><butto
推荐度:
导读前端js打印(导出)excel表格的方法实例:本文主要和大家分享前端js打印(导出)excel表格的方法实例,希望能帮助到大家。产品原型:图片.png功能需求:点击导出考勤表格按钮,会自动下载成Excel格式图片.png图片.pngjsp页面代码:<p class="tools"><butto
 本文主要和大家分享前端js打印(导出)excel表格的方法实例,希望能帮助到大家。

产品原型:

图片.png

功能需求:点击导出考勤表格按钮,会自动下载成Excel格式

图片.png

图片.png

jsp页面代码:

<p class="tools"><button type="button" class="btn green" id="excell" onclick="method5('dataTable')">导出考勤表</button></p>

js代码

//打印表格var idTmr; 
function getExplorer() { 
 var explorer = window.navigator.userAgent ; 
 //ie 
 if (explorer.indexOf("MSIE") >= 0) { return 'ie';
 } //firefox 
 else if (explorer.indexOf("Firefox") >= 0) { return 'Firefox';
 } //Chrome 
 else if (explorer.indexOf("Chrome") >= 0) { return 'Chrome';
 } //Opera 
 else if (explorer.indexOf("Opera") >= 0) { return 'Opera';
 } //Safari 
 else if (explorer.indexOf("Safari") >= 0) { return 'Safari';
 }
 } function method5(tableid) { if (getExplorer() == 'ie') { var curTbl = document.getElementById(tableid); var oXL = new ActiveXObject("Excel.Application"); var oWB = oXL.Workbooks.Add(); var xlsheet = oWB.Worksheets(1); var sel = document.body.createTextRange();
 sel.moveToElementText(curTbl);
 sel.select();
 sel.execCommand("Copy");
 xlsheet.Paste();
 oXL.Visible = true; 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);
 oXL.Quit();
 oXL = null;
 idTmr = window.setInterval("Cleanup();", 1);
 }

 } else {
 tableToExcel(tableid)
 }
 } function Cleanup() { window.clearInterval(idTmr);
 CollectGarbage();
 } var tableToExcel = (function() { var uri = 'data:application/vnd.ms-excel;base,', template = '<html><head><meta charset="UTF-8"></head><body><table border="1">{table}</table></body></html>', base = 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 + base(format(template, ctx))
 }
 })()

完整的可复制黏贴的demo:

<!DOCTYPE html><html>

 <head>
 <meta charset="UTF-8">
 <title></title>
 </head>

 <body>
 <p class="tools">
 <button type="button" class="btn green" id="excell" onclick="method5('dataTable')">导出考勤表格</button>
 </p>

 <table border="1" id="dataTable">
 <tr>
 <td>王婷111</td>
 <td>一见倾城333 </td>
 </tr>
 <tr>
 <td>祈澈姑娘222</td>
 <td>Python开发者交流平台44</td>
 </tr>
 <tr>
 <td>wwwangting888</td>
 <td>13661725475</td>
 </tr>
 </table>

 </body>
 <script>
 //打印表格
 var idTmr; function getExplorer() { var explorer = window.navigator.userAgent; //ie 
 if(explorer.indexOf("MSIE") >= 0) { return 'ie';
 } //firefox 
 else if(explorer.indexOf("Firefox") >= 0) { return 'Firefox';
 } //Chrome 
 else if(explorer.indexOf("Chrome") >= 0) { return 'Chrome';
 } //Opera 
 else if(explorer.indexOf("Opera") >= 0) { return 'Opera';
 } //Safari 
 else if(explorer.indexOf("Safari") >= 0) { return 'Safari';
 }
 } function method5(tableid) { if(getExplorer() == 'ie') { var curTbl = document.getElementById(tableid); var oXL = new ActiveXObject("Excel.Application"); var oWB = oXL.Workbooks.Add(); var xlsheet = oWB.Worksheets(1); var sel = document.body.createTextRange();
 sel.moveToElementText(curTbl);
 sel.select();
 sel.execCommand("Copy");
 xlsheet.Paste();
 oXL.Visible = true; 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);
 oXL.Quit();
 oXL = null;
 idTmr = window.setInterval("Cleanup();", 1);
 }

 } else {
 tableToExcel(tableid)
 }
 } function Cleanup() { window.clearInterval(idTmr);
 CollectGarbage();
 } var tableToExcel = (function() { var uri = 'data:application/vnd.ms-excel;base,',
 template = '<html><head><meta charset="UTF-8"></head><body><table border="1">{table}</table></body></html>',
 base = 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 + base(format(template, ctx))
 }
 })() </script></html>

文档

前端js打印(导出)excel表格的方法实例

前端js打印(导出)excel表格的方法实例:本文主要和大家分享前端js打印(导出)excel表格的方法实例,希望能帮助到大家。产品原型:图片.png功能需求:点击导出考勤表格按钮,会自动下载成Excel格式图片.png图片.pngjsp页面代码:<p class="tools"><butto
推荐度:
标签: 表格 导出 excel
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top