JavaScript的JSON.parse和JSON.stringify怎么用?

json.parse 用于将 json 字符串转换为 javascript 对象,而 json.stringify 则用于将 javascript 对象转换为 json 字符串。1. json.parse 通过反序列化接收 json 字符串并返回对象,若格式错误则抛出 syntaxerror;2. json.parse 可接受 reviver 函数以处理键值对,如将日期字符串转为 date 对象;3. json.stringify 将对象序列化为 json 字符串,可使用 replacer 函数过滤或修改属性;4. json.stringify 支持 space 参数美化输出格式,如指定缩进空格数;5. 它们在 web 开发中用于客户端与服务器间的数据交换;6. 可处理嵌套结构并通过 reviver/replacer 递归操作;7. 大型数据需注意性能优化,如减少不必要的转换和使用第三方库处理流式数据;8. 常见陷阱包括忘记双引号、循环引用导致错误、date 对象处理不当及忽略 undefined、function 和 symbol 类型。

JavaScript的JSON.parse和JSON.stringify怎么用?

JSON.parse 用于将 JSON 字符串转换为 JavaScript 对象,而 JSON.stringify 则相反,用于将 JavaScript 对象转换为 JSON 字符串。它们是 JavaScript 中处理 JSON 数据的重要工具

JavaScript的JSON.parse和JSON.stringify怎么用?

解决方案

JSON.parse() 方法用于将接收到的 JSON 格式字符串转换为 JavaScript 对象。这个过程也称为“反序列化”。如果 JSON 字符串格式不正确,JSON.parse() 会抛出一个错误。

基本用法:

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

JavaScript的JSON.parse和JSON.stringify怎么用?

const jsonString = '{"name":"John", "age":30, "city":"New York"}';const obj = JSON.parse(jsonString);console.log(obj.name); // 输出: Johnconsole.log(obj.age);  // 输出: 30

错误处理:

JSON 字符串的格式必须严格符合 JSON 规范。否则,JSON.parse() 会抛出 SyntaxError

JavaScript的JSON.parse和JSON.stringify怎么用?

try {  const invalidJson = "{name:'John', age:30}"; // 错误: 属性名必须用双引号  const obj = JSON.parse(invalidJson);  console.log(obj);} catch (e) {  console.error("JSON 解析错误:", e);}

reviver 函数:

JSON.parse() 还可以接受一个可选的 reviver 函数作为第二个参数。reviver 函数会在解析过程中,递归地处理每个键值对。这允许你修改解析后的值。

const jsonString = '{"date":"2023-10-27T10:00:00.000Z"}';const obj = JSON.parse(jsonString, (key, value) => {  if (key === 'date') {    return new Date(value);  }  return value;});console.log(obj.date); // 输出: Fri Oct 27 2023 18:00:00 GMT+0800 (中国标准时间)console.log(obj.date instanceof Date); // 输出: true

JSON.stringify() 方法用于将 JavaScript 对象转换为 JSON 格式的字符串。这个过程也称为“序列化”。

基本用法:

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

const obj = { name: "John", age: 30, city: "New York" };const jsonString = JSON.stringify(obj);console.log(jsonString); // 输出: {"name":"John","age":30,"city":"New York"}

replacer 函数:

JSON.stringify() 可以接受一个 replacer 函数作为第二个参数。replacer 函数允许你过滤或修改要序列化的值。

const obj = { name: "John", age: 30, city: "New York", salary: 80000 };const jsonString = JSON.stringify(obj, (key, value) => {  if (key === 'salary') {    return undefined; // 排除 salary 属性  }  return value;});console.log(jsonString); // 输出: {"name":"John","age":30,"city":"New York"}

space 参数:

JSON.stringify() 还可以接受一个 space 参数作为第三个参数,用于美化输出的 JSON 字符串。space 可以是一个数字(表示空格的数目)或一个字符串(用作缩进)。

const obj = { name: "John", age: 30, address: { street: "123 Main St", city: "New York" } };const jsonString = JSON.stringify(obj, null, 2); // 使用 2 个空格缩进console.log(jsonString);// 输出:// {//   "name": "John",//   "age": 30,//   "address": {//     "street": "123 Main St",//     "city": "New York"//   }// }

为什么需要 JSON.parse 和 JSON.stringify?

在 Web 开发中,JSON 格式被广泛用于客户端和服务器之间的数据交换。JSON.parseJSON.stringify 使得在 JavaScript 中轻松地处理 JSON 数据成为可能。例如,当你从服务器接收到 JSON 数据时,你需要使用 JSON.parse 将其转换为 JavaScript 对象,以便在客户端进行操作。反之,当你需要将 JavaScript 对象发送到服务器时,你需要使用 JSON.stringify 将其转换为 JSON 字符串。

如何处理复杂的 JSON 结构?

对于嵌套的 JSON 对象或数组,JSON.parseJSON.stringify 仍然适用。reviverreplacer 函数可以递归地处理嵌套的结构。

const complexObj = {  name: "John",  age: 30,  address: {    street: "123 Main St",    city: "New York",    zip: "10001"  },  hobbies: ["reading", "hiking", "coding"]};const complexJson = JSON.stringify(complexObj, null, 2);console.log(complexJson);const parsedObj = JSON.parse(complexJson);console.log(parsedObj.address.city); // 输出: New York

JSON.parse 和 JSON.stringify 的性能考量

对于大型 JSON 数据,JSON.parseJSON.stringify 的性能可能会成为一个问题。通常,原生实现的性能已经足够好,但在某些情况下,可以考虑以下优化:

避免不必要的序列化和反序列化。使用 replacer 函数过滤掉不需要的属性,减少序列化的数据量。如果可能,使用流式处理来处理大型 JSON 数据。虽然 JavaScript 原生不支持流式 JSON 解析,但可以使用第三方库来实现。

JSON.parse 和 JSON.stringify 的常见错误和陷阱

忘记使用双引号: JSON 规范要求属性名必须使用双引号。处理循环引用: JSON.stringify 不能处理包含循环引用的对象。如果对象包含循环引用,JSON.stringify 会抛出一个 TypeErrorDate 对象的处理: JSON.stringify 会将 Date 对象转换为 ISO 格式的字符串。JSON.parse 默认不会将 ISO 格式的字符串转换回 Date 对象,需要使用 reviver 函数手动转换。undefined、Function 和 Symbol: JSON.stringify 会忽略 undefinedFunctionSymbol 类型的属性值。在数组中,这些值会被转换为 null

以上就是JavaScript的JSON.parse和JSON.stringify怎么用?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1510272.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月20日 05:51:38
下一篇 2025年12月20日 05:51:50

相关推荐

  • 使用 JavaScript LocalStorage 实现计算器数字历史记录

    本文将介绍如何利用 JavaScript 的 LocalStorage 功能,为计算器实现一个简单的数字历史记录功能。该功能可以保存用户最近输入的 5 个数字,并在每次输入新数字时,将最早的数字移除,从而实现一个类似队列的历史记录效果。通过本文的学习,你将掌握 LocalStorage 的基本用法,…

    2025年12月20日
    000
  • Jasmine 异步 Mock 函数调用两次后测试停止:解决方案与分析

    本文旨在解决 Jasmine 测试中异步 mock 函数在同一测试函数中被多次调用后,后续断言失败的问题。通过分析问题代码,定位到原因是应用代码中缺少 async/await 关键字,导致测试未正确等待异步操作完成。文章提供修复后的代码示例,并强调了在测试异步代码时正确使用 async/await …

    2025年12月20日
    000
  • Jasmine 测试异步 Mock 函数多次调用失败问题排查与解决

    本文旨在解决 Jasmine 测试中,异步 Mock 函数在同一个测试函数内被多次调用时,后续调用无法正确执行的问题。通过分析问题原因,提供有效的解决方案,并给出完整的代码示例,帮助开发者避免类似错误,确保测试的准确性和可靠性。 在 Jasmine 中测试异步代码时,经常会用到 jasmine.cr…

    2025年12月20日
    000
  • Jasmine 异步 Mock 函数测试中断问题排查与解决

    本文旨在解决 Jasmine 测试框架中,异步 mock 函数在同一测试函数内被多次调用时,测试中断或结果不符合预期的问题。通过分析问题现象、代码示例,以及最终解决方案,帮助开发者理解异步测试中的关键点,并提供完整的可运行代码示例,确保测试的准确性和可靠性。 在 Jasmine 中进行异步测试时,如…

    2025年12月20日
    000
  • 使用 Jest 进行 JavaScript REST GET 请求的单元测试

    本文档旨在指导开发者如何使用 Jest 框架为 JavaScript 中的 REST GET 请求编写单元测试。我们将通过示例代码,详细介绍如何模拟 HTTP 请求、验证响应状态码和数据,以及处理错误情况,帮助你构建健壮可靠的测试用例,确保代码质量。 使用 Jest 测试 JavaScript RE…

    2025年12月20日
    000
  • 深入理解与实践:使用Jest测试Node.js REST GET请求封装函数

    本文详细介绍了如何使用Jest框架为Node.js中封装的REST GET请求函数编写单元测试。我们将深入探讨如何模拟HTTP请求(如https.get),处理异步回调,以及验证不同响应场景(成功、错误、JSON/非JSON数据)下的函数行为。通过具体的代码示例,帮助读者掌握高效、可靠的Node.j…

    2025年12月20日
    000
  • Web3Forms表单提交:动态设置邮件主题的正确方法

    本文详细介绍了在使用Web3Forms构建HTML联系表单时,如何将用户输入的表单主题字段值作为提交邮件的实际主题。通过纠正常见的配置误区,特别是避免使用隐藏字段或JavaScript函数来尝试动态获取主题,我们揭示了Web3Forms内置的简便机制:只需将表单中用于主题输入的字段的name属性直接…

    好文分享 2025年12月20日
    000
  • 自定义HTML表单提交主题的简洁方法

    推荐的优化方案: 删除不必要的隐藏input字段和相关的JavaScript函数。然后,将用户输入主题的文本字段的name属性从text修改为subject。 通过这一简单的修改,当用户在“Your subject…”字段中输入内容并提交表单时,Web3Forms服务会自动识别name=…

    2025年12月20日
    000
  • async函数中的并行与串行控制

    并行处理适用于无依赖任务,使用promise.all()或promise.allsettled()实现;串行处理用于需顺序执行的场景,可通过循环或reduce链式调用完成;有限并发控制可借助任务队列和并发计数器平衡效率与资源占用。 在异步函数的世界里,并行与串行控制是我们日常编码中不可或缺的考量。简…

    2025年12月20日 好文分享
    000
  • async函数中的并发执行控制

    并发控制在async函数中的核心目的是避免资源耗尽、接口限流或服务崩溃,通过限制同时运行的异步任务数量来维持系统稳定。1. 基于计数器和队列的自定义实现通过维护任务队列和执行计数器动态管理任务执行;2. 使用promise.all结合分块处理适用于固定任务列表的场景,将任务分为小批次串行执行;3. …

    2025年12月20日 好文分享
    000
  • ES6的Error子类如何自定义错误类型

    自定义es6错误类型能提升代码质量与错误处理的精确性。通过继承error类,开发者可创建具有语义化名称和附加上下文信息的错误类型,如validationerror和networkerror,从而告别模糊的错误提示。使用class语法定义错误类型时,需在构造函数中调用super()并设置name属性,…

    2025年12月20日 好文分享
    000
  • 如何处理JavaScript中的异步错误

    javascript中处理异步错误的核心方法包括使用async/await结合try/catch、promise的.catch()方法、promise.allsettled()以及全局错误监听机制。1. async/await与try/catch结合能以同步方式捕获异步错误,适用于现代异步编程;2.…

    2025年12月20日 好文分享
    000
  • ES6的类语法如何实现继承

    super关键字在es6类继承中用于调用父类的构造函数或方法。1. super()必须在子类构造函数中调用,用于执行父类构造函数并绑定this;2. super.methodname()可调用父类方法,便于扩展其行为;3. this只能在super()后使用,因super()负责初始化父类属性;4.…

    2025年12月20日 好文分享
    000
  • JavaScript中异步编程的历史演变

    javascript异步编程的核心问题是单线程环境下高效处理耗时操作而不阻塞主线程。1. 最初使用回调函数,导致“回调地狱”,代码可读性和维护性差;2. promise引入状态管理和链式调用,解决了嵌套问题并统一了错误处理;3. async/await作为promise的语法糖,让异步代码几乎像同步…

    2025年12月20日 好文分享
    000
  • JavaScript中生成器与异步编程

    生成器在异步控制流中的核心作用是作为“流程协调员”,提供非阻塞式的暂停与恢复机制。①通过function*和yield关键字,允许函数中途暂停并将值“吐”出,外部通过next()方法传回值并继续执行;②支持以同步方式编写异步代码,提升可读性和维护性;③提供统一的错误处理机制,通过generator.…

    2025年12月20日 好文分享
    000
  • ES6中如何用数组的flatMap方法映射并展平

    flatmap为何出现?1.解决映射后展平常见场景,避免map+flat两步操作;2.提升代码可读性与意图表达清晰度;3.潜在性能优化,减少中间数组生成。flatmap是map后接flat(1)的语法糖,对每个元素应用回调并展平一层,使代码更简洁高效。例如,插入分隔项或提取多标签时,flatmap能…

    2025年12月20日 好文分享
    000
  • JavaScript如何用数组的at方法获取末尾元素

    在javascript中,数组的at()方法通过负数索引(如-1)更直观地获取末尾元素。传统方式需使用arr[arr.length – 1]进行计算,而at(-1)直接表达“获取最后一个元素”的意图,提升可读性;它支持链式调用,适用于复杂表达式、倒数任意元素获取、函数式编程风格及处理空数…

    2025年12月20日 好文分享
    000
  • Promise中的then方法详解

    then方法通过返回新promise实现链式调用,允许异步操作按顺序执行。1. then接受onfulfilled和onrejected回调,分别处理成功与失败;2. 回调执行结果决定新promise状态:返回值解决、抛出错误拒绝、返回promise则采纳其状态;3. 回调异步执行,确保一致性;4.…

    2025年12月20日 好文分享
    000
  • ES6的导出别名如何重命名模块

    es6中重命名模块导出通过as关键字实现,允许在不改变原始变量名的情况下以不同名字暴露。1. 重命名具名导出:使用export { originalname as newname }语法,如export { add as sum, subtract as minus }; 2. 重命名默认导出:通过…

    2025年12月20日 好文分享
    000
  • ES6中如何用正则表达式的d标志获取索引

    es6引入的正则d标志能获取捕获组索引。1. 使用d标志后,exec()返回的匹配对象新增indices属性;2. indices数组包含每个捕获组的[startindex, endindex]对;3. 该功能解决了手动计算索引易出错的问题;4. 可用于语法高亮、模板解析、富文本编辑等场景;5. m…

    2025年12月20日 好文分享
    000

发表回复

登录后才能评论
关注微信