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

#Js篇:JSON.stringify 和 JSON.parse用法和传参

JSON.stringify 和 JSON.parse

1. JSON.stringify

JSON.stringify 方法将一个 JavaScript 对象或数组转换为 JSON 字符串。

基本用法

const obj = { name: "Alice", age: 25 };
const jsonString = JSON.stringify(obj);
console.log(jsonString); // 输出: {"name":"Alice","age":25}
参数

value: 要转换的对象或数组。
replacer (可选): 一个函数或数组,用于控制哪些属性会被序列化到字符串中。
space (可选): 用于控制缩进的字符串或数字,使输出更易读。
使用 replacer 函数

const obj = { name: "Alice", age: 25, city: "New York" };
const jsonString = JSON.stringify(obj, function(key, value) {if (key === 'city') return undefined; // 排除 city 属性return value;
});
console.log(jsonString); // 输出: {"name":"Alice","age":25}
使用 space 参数
javascript
const obj = { name: "Alice", age: 25 };
const jsonString = JSON.stringify(obj, null, 2);
console.log(jsonString);
// 输出:
// {
//   "name": "Alice",
//   "age": 25
// }

2. JSON.parse

JSON.parse 方法将一个 JSON 字符串解析为 JavaScript 对象或数组。

基本用法

const jsonString = '{"name":"Alice","age":25}';
const obj = JSON.parse(jsonString);
console.log(obj); // 输出: { name: 'Alice', age: 25 }
参数

text: 要解析的 JSON 字符串。
reviver (可选): 一个函数,用于在返回之前对每个键值对进行处理。
使用 reviver 函数

const jsonString = '{"name":"Alice","age":25,"birthDate":"1998-03-14"}';
const obj = JSON.parse(jsonString, function(key, value) {if (key === 'birthDate') return new Date(value); // 将 birthDate 转换为日期对象return value;
});
console.log(obj.birthDate instanceof Date); // 输出: true

总结

JSON.stringify 用于将 JavaScript 对象或数组转换为 JSON 字符串。
JSON.parse 用于将 JSON 字符串解析为 JavaScript 对象或数组。
这两个方法都支持额外的参数来定制其行为,如 replacer 和 reviver 函数,以及 space 参数。

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

相关文章:

  • c#通过网上AI大模型实现对话功能
  • pymysql模块
  • WPF-模板和样式
  • 网络编程 day1.2~day2——TCP和UDP的通信基础(TCP)
  • element ui table 每行不同状态
  • 力扣--LRC 142.训练计划IV
  • windows下,用CMake编译qt项目,出现错误By not providing “FindQt5.cmake“...
  • 【element-tiptap】Tiptap编辑器核心概念----结构篇
  • 半导体工艺与制造篇3 离子注入
  • 利用开源的低代码表单设计器FcDesigner高效管理和渲染复杂表单结构
  • 淘宝 NPM 镜像源
  • i春秋-GetFlag(md5加密,字符串比较绕过)
  • SpringBoot中设置超时30分钟自动删除元素的List和Map
  • 入门车载以太网(6) -- XCP on Ethernet
  • DAY4 网络编程(广播和多线程并发)
  • C++个人复习(4)
  • Dockerhub镜像加速
  • 11.20讲座笔记
  • 网络协议之UDP
  • Elasticsearch面试内容整理-常见问题和解决方案
  • React 表单Form 中的 useForm
  • 用指针函数寻找数组中的最大值与次大值
  • 人工智能在金融领域的创新与应用
  • shell脚本(4)一文解决比较运算符用户交互
  • windows 操作系统下载 Android源码教程
  • 【AIGC】如何使用高价值提示词Prompt提升ChatGPT响应质量
  • vue3-input 搜索框
  • 记录eslint报错的情况
  • mongodb多表查询,五个表查询
  • Git Bash + VS Code + Windows11 Git命令报错莫名奇妙的问题