有很多方法可以将 html 表导出到 excel,但是 jtable 不包含像 <table>
这样的 html 标签呢?在页面中,它只是通过 ID 调用,如 <div id="table"></div>
我有一个简单的解决方案,可以在 Chrome 上运行,但不能在 IE 上运行
导出按钮:
<a id="dlink" onclick="tableToExcel('StudentTableContainer', 'name', 'TestExcelFile.xls')">Export to excel</a>
J表:
<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 上使用吗?
- 我们怎样才能显示所有的值 table ? (因为此解决方案仅导出页面上显示的行)
我正在使用 vb.net 获取 jtable 的 sql 值
最佳答案
为了导出所有行,您可以创建另一个不带分页的 jtable,您仅在导出前加载它,并且对最终用户不可见。应该是这样的:
$('#PersonTable').jtable({
//...
paging: false, //Set paging disabled
actions: {
//...
},
fields: {
//...
}
});
获得完整的 jtable 后,您可以使用 this forum 中的解决方案将其导出.您可以在第二个 jtable 中仅指定要在 excel 中导出的列。
关于javascript - 将 jtable 导出到 IE 上的 javascript 中的 excel,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30450462/