
在 Web 开发中,经常需要将 HTML 表格导出为 Excel 文件。常见的实现方式是利用 data:application/vnd.ms-excel;base64 URI scheme 来模拟文件下载。然而,默认情况下,导出的文件名通常为 "download.xls",这在实际应用中往往不够灵活。本文将详细介绍如何修改 JavaScript 代码,以便在导出 Excel 文件时自定义文件名。
核心在于使用 <a> 标签的 download 属性。该属性允许我们指定下载文件的名称。以下是修改后的 JavaScript 代码:
function tableToExcel(table, name) {
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" content="application/vnd.ms-excel; 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];
})
}
if (!table.nodeType) table = document.getElementById(table)
var ctx = {
worksheet: name || 'Worksheet',
table: table.innerHTML
}
var a = document.createElement('a');
a.href = uri + base64(format(template, ctx));
a.download = name + '.xls'; // 设置下载文件名
a.click(); // 触发下载
}代码解释:
假设你的 HTML 表格的 ID 为 "myTable",并且你想将导出的 Excel 文件命名为 "SalesReport"。你可以这样调用 tableToExcel 函数:
立即学习“前端免费学习笔记(深入)”;
<button onclick="tableToExcel('myTable', 'SalesReport')">导出 Excel</button>通过使用 <a> 标签的 download 属性,我们可以轻松地在导出 HTML 表格到 Excel 文件时自定义文件名。这种方法简单易用,并且在大多数现代浏览器中都能正常工作。希望本文能够帮助你解决导出 Excel 文件时文件名的问题。
以上就是如何在导出 HTML 表格到 Excel 时更改文件名?的详细内容,更多请关注php中文网其它相关文章!
HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号