当前位置: 首页 > news >正文

JSON.stringify 和 JSON.parse

JSON.stringify 是一个将 JavaScript 对象转换为 JSON 字符串的方法,它有三个参数:

JSON.stringify(value, replacer, space)

参数详解

  1. value (必需):

    • 这是你想要转换为 JSON 字符串的 JavaScript 对象或数组。
    • 例如:JSON.stringify({ name: "Alice", age: 25 })
  2. replacer (可选):

    • 这个参数可以是一个函数或数组,用来选择或改变对象属性的字符串化过程。
    • 如果是一个函数,它将在每个键值对上调用,可以用来筛选或改变值。
    • 如果是一个数组,它指定哪些属性应该包含在最终的 JSON 字符串中。
    • 如果省略此参数,则将对对象的所有属性进行字符串化。
    • 示例:

      • 函数形式
JSON.stringify({ name: "Alice", age: 25 }, (key, value) => {if (typeof value === 'number') {return undefined; // 过滤掉数值型属性}return value;
});
// 输出: {"name":"Alice"}

                        2. 数组形式

JSON.stringify({ name: "Alice", age: 25, gender: "female" },["name", "gender"]);
// 输出: {"name":"Alice","gender":"female"}

3.space (可选):

  • 这个参数用于控制输出的 JSON 字符串的缩进,主要用于格式化输出,使其更易读。
  • 如果传递一个数字(如 2),每一层嵌套将缩进相应数量的空格。
  • 如果传递一个字符串(如 "\t"),将使用该字符串作为缩进。
  • 如果为 null 或者省略,输出的 JSON 字符串将是没有任何缩进或换行的紧凑形式。

示例

  • 数字形式
JSON.stringify({ name: "Alice", age: 25 }, null, 2);

   · 字符串形式

JSON.stringify({ name: "Alice", age: 25 }, null, "\t");

JSON.parse 是一个将 JSON 字符串转换为 JavaScript 对象的方法。它有两个参数:

JSON.parse(text, reviver)

参数详解

  1. text (必需):

    • 这是一个有效的 JSON 字符串,需要被解析成 JavaScript 对象
    • JSON 字符串必须使用双引号 " 包围键和字符串值,并且必须是有效的 JSON 格式,否则会抛出 SyntaxError 异常。
    • 例如:'{"name": "Alice", "age": 25}' 是一个有效的 JSON 字符串。
  2. reviver (可选):

    • 这是一个可选的函数参数,可以用来逐个检查或转换解析后的对象的每个属性值
    • 如果提供了 reviver 函数,它会为对象的每个键值对调用,并且可以返回一个修改后的值,或者如果返回 undefined,则该属性将被从最终结果中删除。
    • reviver 函数接收两个参数:key(当前属性的键)和 value(当前属性的值)。

    示例

const jsonString = '{"name": "Alice", "age": 25}';// 解析 JSON 字符串并使用 reviver 函数来过滤属性
const parsedObject = JSON.parse(jsonString, (key, value) => {if (typeof value === 'number') {return value * 2; // 将数值属性加倍}return value; // 返回原始值
});console.log(parsedObject);
// 输出: { name: "Alice", age: 50 }

   

http://www.lryc.cn/news/429527.html

相关文章:

  • APP架构设计_2.用MVVM架构实现一个具体业务
  • 安恒信息总裁宋端智,辞职了!活捉一枚新鲜出炉的餐饮人!
  • 《javaEE篇》--定时器
  • OpenLayers3, 缩放、平移、复位操作
  • 进程与线程(7)
  • 传知代码-自动化细胞核分割与特征分析(论文复现)
  • Vue UI - 可视化的Vue项目管理器
  • 团队管理之敏捷开发
  • Hive3:表的常用修改语句
  • MidJourney付费失败的原因以及失败后如何取消或续订(文末附MidJourney,GPT-4o教程)
  • PHP安全开发
  • 【大模型从入门到精通32】开源库框架LangChain RAG 系统中的问答技术2
  • MySQL 数据库管理
  • 屏幕录制了一个视频,发现有些部分是不需要的,那么我们就用到视频剪辑的工具,利用必剪去删除中间的一部分视频,并且导出,然后利用格式工厂去压缩mp4文件的过程。
  • 代码随想录跟练第六天——LeetCode
  • 【Qt】常用控件QCalendarWidget的使用
  • Nginx: 配置项之main段核心参数用法梳理
  • 密码学之RSA算法
  • 教你学习企业高性能web服务器-nginx
  • 封装通用第三方平台用户表(微信开放平台)
  • 【C++】_string类字符串详细解析(1)
  • 【Linux】——进程概念(万字解读)
  • 03 serv00搭建WordPress
  • 伪共享问题如何解决?
  • 基于web框架的协同过滤的美食推荐系统【数据爬虫、管理系统、数据可更新、样式可调整】
  • Eureka中的多实例配置:如何处理微服务实例动态扩展与缩减
  • Ubuntu 22.04使用 IPTables 配置防火墙
  • Java语言程序设计——篇十三(1)
  • GB/T 5023.3-2008额定电压450/750V及以下聚氯乙烯绝缘电缆
  • 深入单例模式