本文介绍如何使用 sheetjs(xlsx.js)导出 html 表格为 excel 文件时,智能跳过被 javascript 隐藏的行(如搜索过滤后隐藏的 `
在 Web 应用中,常需将动态筛选后的 HTML 表格导出为 Excel。但若直接调用 XLSX.utils.table_to_book() 导出原始 DOM 表格,所有
根本原因:table_to_book() 仅解析 HTML 结构,不感知 CSS 样式(如 display: none)或运行时状态。因此,必须在导出前主动构造一个精简版 DOM 表格,只保留真正应导出的行。
推荐将隐藏逻辑从 style.display = "none" 升级为原生 row.hidden = true/false(语义更清晰,且便于后续 DOM 筛选)。修改 search() 函数如下:
function search(tableId) {
const table = document.getElementById(tableId);
// 从第2行开始(跳过表头和搜索行)
const rows = Array.from(table.querySelectorAll('tbody tr')).slice(1);
rows.forEach(row => {
let shouldHide = false;
const cells = row.querySelectorAll('td');
for (let j = 0; j < cells.length; j++) {
const input = document.getElementById(`REC_${j}`);
if (input && input.value.trim()) {
const cellText = cells[j].textContent.toLowerCase();
if (!cellText.includes(input.value.toLowerCase())) {
shouldHide = true;
break;
}
}
}
row.hidden = shouldHide; // 使用 hidden 属性标记
});
}htmlTableToExcel() 需创建副本、过滤掉 hidden 行及搜索行(.header),再传给 SheetJS:
function htmlTableToExcel(type, tableId) {
const originalTable = document.getElementById(tableId);
const cloneTable = document.createElement('table');
cloneTable.innerHTML = originalTable.innerHTML;
// 移除所有 hidden 行,以及 tbody 中的 .header 搜索行
cloneTable.querySelectorAll('tr').forEach(row => {
if (row.hidden ||
(row.closest('tbody') && row.classList.contains('header'))) {
row.remove();
}
});
// 使用净化后的表格生成 Excel
const workbook = XLSX.utils.table_to_book(c
loneTable, { sheet: 'Data' });
XLSX.writeFile(workbook, `MyTable.${type}`);
}该方案轻量、可靠、符合 Web 标准,是动态表格导出场景下的推荐实践。