У меня есть страница html с несколькими таблицами, я хочу экспортировать эти таблицы в один файл Excel на одном листе. Как мне это сделать. Я попробовал следующий код, и он отлично работает с 1 таблицей. Как изменить код для экспорта нескольких таблиц?
var tableToExcel = () => {
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) {
if (!table.nodeType) table = document.getElementById(table)
var ctx = {
worksheet: name || 'Worksheet',
table: table.innerHTML
}
window.location.href = uri + base64(format(template, ctx))
}
}
<table id="testTable">
<tr>
<td>a</td>
<td>aaa</td>
<td>aaaaaa</td>
</tr>
<tr>
<td>b</td>
<td>bbb</td>
<td>bbbbbb</td>
</tr>
</table>
<table id="testTable2">
<tr>
<td>222a</td>
<td>222aaa</td>
<td>222aaaaaa</td>
</tr>
<tr>
<td>222b</td>
<td>22bbb</td>
<td>222bbbbbb</td>
</tr>
</table>
<button onclick="tableToExcel('testTable', 'W3C Example Table')">Export</button>