在IE浏览器中将jtable导出为ex​​cel

有很多方法可以将html表格导出为ex​​cel,但是jtable又如何,因为它不包含页面中的<table>类的html标签,所以只需要调用id <div id="table"></div>

我有简单的解决scheme,在Chrome上工作,但没有在IE上工作

导出button:

 <a id="dlink" onclick="tableToExcel('StudentTableContainer', 'name', 'TestExcelFile.xls')">Export to excel</a> 

JTable的:

 <div id="StudentTableContainer"></div> 

使用Javascript:

 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"><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, filename) { if (!table.nodeType) table = document.getElementById(table) var ctx = { worksheet: name || 'Worksheet', table: table.innerHTML } document.getElementById("dlink").href = uri + base64(format(template, ctx)); document.getElementById("dlink").download = filename; document.getElementById("dlink").click(); } })() 
  • 我们可以使它在IE上使用吗?
  • 我们如何显示表格的所有值? (因为此解决scheme仅导出页面上显示的行)

我正在使用vb.net获取jtable的sql值

为了让所有行导出,您可以创build另一个没有分页的jtable,只在导出之前加载,而对最终用户不可见。 应该是这样的:

 $('#PersonTable').jtable({ //... paging: false, //Set paging disabled actions: { //... }, fields: { //... } }); 

完整的jtable之后,您可以使用本论坛的解决scheme将其导出。 你可以在这个第二个jtable中只指定你想在excel中导出的列。