JSON转表格需四层防御:字段对齐(合并去重键)、异常兜底(空数组/缺字段/类型转换)、性能边界(文档片段/虚拟滚动)、浏览器兼容(fetch/Promise Polyfill)。
Object.keys() 不能直接用很多新手看到 JSON 就想直接 Object.keys(data[0]) 拿表头,结果报错或漏字段——因为 data 可能是空数组、单个对象、嵌套对象,甚至每条记录字段都不一致。比如后端返回的 { "users": [ {...}, {...} ] },你得先解出 users 数组;又或者某条数据缺 email 字段,直接取键会导致列错位。
实操建议:
立即学习“前端免费学习笔记(深入)”;
Array.isArray(data) 或 Array.isArray(data.users)
data.length > 0 ? Object.keys(data[0]) : [] 获取表头,避免空数组报错[...new Set(data.flatMap(obj => Object.keys(obj)))]
for...in 遍历对象,优先用 Object.entries() 保证顺序和可读性innerHTML += 会卡死页面把几百条 JSON 循环拼接字符串再赋给 innerHTML,看似简单,实际触发多次 DOM 重排,滚动卡顿、输入延迟都是常见现象。尤其在移动端或低配设备上,500 条数据就可能让页面“假死”。
实操建议:
立即学习“前端免费学习笔记(深入)”;
document.createDocumentFragment() 批量创建行节点,最后一次性挂载Array.from(data).map(...).join('') 生成完整 HTML 字符串,再整体赋值给 innerHTML(注意 XSS!)IntersectionObserver 做懒加载document.getElementById('table'),提前缓存引用[object Object] 或 undefined
JSON 里的 new Date() 已被序列化为字符串,但布尔值 true、null、undefined 进入单元格后,若没显式转字符串,某些浏览器会显示为空白或 undefined;更隐蔽的是嵌套对象如 { id: 1, profile: { name: 'A' } },直接 cell.textContent = row.profile 就变成 [object Object]。
实操建议:
立即学习“前端免费学习笔记(深入)”;
String(value) === 'undefined' ? '' : String(value)
new Date(value).toLocaleString()(需校验 value 是合法时间字符串)JSON.stringify(value, null, 2) 缩进展示,或加「展开」按钮折叠user.email)时,别用 row['user.email'],改用 _.get(row, 'user.email', '')(Lodash)或手写安全取值函数fetch 和 Promise 报错,但你可能根本没意识到写完本地测试没问题,一上生产就被 IE11 用户投诉“表格空白”,查控制台才发现 fetch is not defined 或 Promises are not supported。这时候不是 JSON 渲染逻辑的问题,而是整个数据获取链路在老浏览器断了。
实操建议:
立即学习“前端免费学习笔记(深入)”;
fetch 前必须加 polyfill(如 whatwg-fetch),且确保它在入口 JS 最顶部执行async/await 同样需要 Babel 编译(@babel/preset-env + targets 配置 IE11)catch 中打印 error.message 和原始响应体(response.text()),否则很难定位是格式问题还是编码问题(如 GBK 返回没声明 charset)http-server 起服务,别直接双击打开 HTML——IE11 下 file:// 协议禁用 fetch