JavaScript中JSON解析核心是JSON.parse()和JSON.stringify(),前者将JSON字符串转为对象,后者将对象序列化为JSON字符串,二者因轻量、通用、安全及浏览器原生支持成为数据交换事实标准。

JavaScript 中的 JSON 解析很简单,核心就是 JSON.parse() 和 JSON.stringify() 这两个方法。它之所以在数据交换中至关重要,是因为它轻量、通用、语言无关,且浏览器原生支持,成了前后端通信的事实标准。
JSON.parse():把字符串变成 JavaScript 对象
后端返回的通常是 JSON 格式的字符串(比如通过 fetch 或 XMLHttpRequest 获取),必须解析才能操作数据。
- 基本用法:
const data = JSON.parse('{"name":"张三","age":28}');→ 得到一个普通对象 - 注意:字符串必须符合 JSON 语法(键名必须双引号、不能有尾逗号、不能用单引号)
- 常见错误:直接解析 undefined、null 或格式错误的字符串会抛出 SyntaxError,建议加 try-catch
JSON.stringify():把 JavaScript 值转成 JSON 字符串
前端要向后端发送结构化数据时,通常需要把它序列化为 JSON 字符串。
- 基本用法:
const str = JSON.stringify({name: "李四", hobbies: ["读书", "跑步"]}); - 可选参数:第二个参数可传 replacer 函数或数组来过滤/修改字段;第三个参数用于缩进(便于调试)
- 注意:函数、undefined、Symbol、Date 对象(默认转为字符串但不标准)、RegExp 等无法被正确序列化,会被忽略或转为 null
为什么 JSON 是数据交换的首选?
不是因为功能最强,而是因为它刚好平衡了可读性、简洁性和兼容性。
JSON 即 JavaScript Object Natation,它是一种轻量级的数据交换格式,非常适合于服务器与 JavaScript 的交互。本文将快速讲解 JSON 格式,并通过代码示例演示如何分别在客户端和服务器端进行 JSON 格式数据的处理。
立即学习“Java免费学习笔记(深入)”;
- 比 XML 更轻量:没有闭合标签、无命名空间、体积更小,传输更快
- 比纯 JS 对象更安全:JSON 不执行代码,避免 eval 带来的风险
- 几乎所有语言都有标准 JSON 库(Python 的 json、Java 的 Jackson、Go 的 encoding/json),跨平台无障碍
- 浏览器 100% 原生支持,无需引入额外依赖,fetch 默认处理 JSON 很方便
实际开发中的典型场景
你几乎每天都在用,只是可能没意识到。
- 调用 REST API:
fetch('/api/user').then(res => res.json()).then(data => {...})——res.json()内部就是封装了JSON.parse() - 本地存储:
localStorage.setItem('user', JSON.stringify(obj)),读取时再JSON.parse() - 配置文件:Vite、Webpack、ESLint 等工具都用 JSON 或 JSONC(带注释的 JSON)管理配置
- 前后端约定接口:Swagger/OpenAPI 文档里定义的数据结构,本质上就是 JSON Schema
不复杂但容易忽略。掌握好 parse 和 stringify 的边界与限制,就能避开大多数数据转换类 bug。










