一聚教程网:一个值得你收藏的教程网站

最新下载

热门教程

HTML怎么做JSON转表格_html JSON数据渲染为表格方法参考

时间:2026-06-26 09:50:05 编辑:袖梨 来源:一聚教程网

JSON转表格需四层防御:字段对齐(合并去重键)、异常兜底(空数组/缺字段/类型转换)、性能边界(文档片段/虚拟滚动)、浏览器兼容(fetch/Promise Polyfill)。

JSON数据结构不规则时,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!)
  • 超过 1000 行考虑虚拟滚动,不要全量渲染;可用 IntersectionObserver 做懒加载
  • 避免在循环里反复查 document.getElementById('table'),提前缓存引用

日期、布尔、null 等值直接塞进表格会显示成 [object Object]undefined

JSON 里的 new Date() 已被序列化为字符串,但布尔值 truenullundefined 进入单元格后,若没显式转字符串,某些浏览器会显示为空白或 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)或手写安全取值函数

IE11 下 fetchPromise 报错,但你可能根本没意识到

写完本地测试没问题,一上生产就被 IE11 用户投诉“表格空白”,查控制台才发现 fetch is not definedPromises are not supported。这时候不是 JSON 渲染逻辑的问题,而是整个数据获取链路在老浏览器断了。

实操建议:

立即学习“前端免费学习笔记(深入)”;

  • fetch 前必须加 polyfill(如 whatwg-fetch),且确保它在入口 JS 最顶部执行
  • async/await 同样需要 Babel 编译(@babel/preset-env + targets 配置 IE11)
  • JSON 解析失败时,catch 中打印 error.message 和原始响应体(response.text()),否则很难定位是格式问题还是编码问题(如 GBK 返回没声明 charset)
  • 本地开发用 http-server 起服务,别直接双击打开 HTML——IE11 下 file:// 协议禁用 fetch
JSON 转表格真正难的不是循环几行代码,而是字段对齐、异常兜底、性能边界和浏览器兼容这四层嵌套判断。多数人卡在第二层就放弃加防错,结果上线后靠用户反馈才发现 null 值让整张表崩溃。

热门栏目