JSON.stringify()和JSON.parse()

news/2024/9/20 15:43:59/

JSON.stringify()

JSON.stringify() 是 JavaScript 中的一个内置方法,用于将一个 JavaScript 值(对象或值)转换为一个 JSON 字符串。这个方法对于在客户端和服务器之间传输数据特别有用,因为 JSON 是一种轻量级的数据交换格式,它基于文本,并且易于人阅读和编写,同时也易于机器解析和生成。

以下是一些 JSON.stringify() 的基本用法和示例:

基本用法

javascript复制代码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),用于在字符串化过程中过滤或转换数据:

javascript复制代码function replacer(key, value) {  if (typeof value === 'string') {  return undefined; // 过滤掉所有字符串  }  return value;  
}  const obj = {  name: 'John',  age: 30,  city: 'New York'  
};  const jsonString = JSON.stringify(obj, replacer);  
console.log(jsonString); // 输出: '{"age":30}'

缩进和空格

你可以使用第三个参数来指定缩进级别(或空格数):

javascript复制代码const obj = {  name: 'John',  age: 30,  city: 'New York'  
};  const prettyJsonString = JSON.stringify(obj, null, 2);  
console.log(prettyJsonString);  
// 输出:  
// {  
//   "name": "John",  
//   "age": 30,  
//   "city": "New York"  
// }

在这个例子中,我们传递了 null 作为第二个参数(因为我们不需要替换函数),并传递了 2 作为第三个参数,表示我们希望每个级别缩进两个空格。

注意事项

  • 循环引用(即对象属性直接或间接地引用自己)会导致 JSON.stringify() 抛出一个错误。
  • 函数和 undefined 会被 JSON.stringify() 忽略(在字符串化过程中不会包含它们)。
  • 对象的 getter 方法在字符串化过程中不会被调用。
  • 日期对象会被转换为一个字符串(按照 ISO 8601 格式)。
  • NaN 和 Infinity 会被替换为 null。
  • 数组和对象会被递归地字符串化。

希望这可以帮助你更好地理解 JSON.stringify() 方法!

JSON.parse()

JSON.parse() 是 JavaScript 中的一个内置方法,用于将一个 JSON 字符串转换回 JavaScript 对象或值。这个方法在处理从服务器接收到的 JSON 数据或在本地解析存储的 JSON 字符串时特别有用。

以下是一些 JSON.parse() 的基本用法和示例:

基本用法

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

处理错误

由于 JSON.parse() 在遇到无效的 JSON 字符串时会抛出一个错误,因此通常建议使用 try...catch 语句来捕获和处理这些错误:

javascript复制代码const jsonString = 'Invalid JSON string';  try {  const obj = JSON.parse(jsonString);  console.log(obj);  
} catch (error) {  console.error('An error occurred:', error);  
}

使用 reviver 函数

JSON.parse() 还接受一个可选的第二个参数,这是一个转换函数(通常被称为 reviver 函数),该函数可以在返回之前对解析的对象中的每个键值对进行处理:

javascript复制代码const jsonString = '{"name":"John","age":30,"city":"New York"}';  function reviver(key, value) {  if (key === 'age' && typeof value === 'number') {  return value + 1; // 将年龄增加 1  }  return value;  
}  const obj = JSON.parse(jsonString, reviver);  
console.log(obj.name); // 输出: John  
console.log(obj.age);  // 输出: 31  
console.log(obj.city); // 输出: New York

在这个例子中,reviver 函数在解析过程中检查了每个键值对。如果键是 'age' 并且值是数字类型,那么它返回的值将是原值加 1。

注意事项

  • 字符串必须是一个有效的 JSON 格式,否则 JSON.parse() 将抛出一个错误。
  • JSON 字符串中的属性名称必须用双引号(")括起来。使用单引号(')或没有引号都将导致解析错误。
  • 如果 JSON 字符串包含注释或尾随逗号,那么 JSON.parse() 将无法正确解析它,因为这些特性不是 JSON 标准的一部分。
  • JSON.parse() 只能解析 JSON 字符串,不能解析 JavaScript 对象字面量或表达式。例如,它不能解析 eval() 可以处理的代码字符串。

补充

当您尝试使用 JSON.parse() 解析一个无效的 JSON 字符串时,JavaScript 会抛出一个 SyntaxError。无效的 JSON 字符串可能包含以下常见问题:

  1. 字符串未用双引号括起来:在 JSON 中,所有的字符串必须使用双引号(")括起来,而不是单引号(')或没有引号。
json复制代码// 无效的 JSON  
{ name: 'John' }  // 有效的 JSON  
{ "name": "John" }
  1. 使用了 JavaScript 注释:JSON 不支持注释。
json复制代码// 无效的 JSON  
{  // 这是一个注释  "name": "John"  
}  // 有效的 JSON(没有注释)  
{  "name": "John"  
}
  1. 尾随逗号:JSON 对象或数组的最后一个元素后不应有逗号。
json复制代码// 无效的 JSON  
{  "name": "John",  "age": 30,  
}  // 有效的 JSON  
{  "name": "John",  "age": 30  
}
  1. 使用了 JavaScript 类型的标识符,如 true、false 或 null,但拼写错误或格式错误。
json复制代码// 无效的 JSON  
{  "active": True  
}  // 有效的 JSON  
{  "active": true  
}
  1. 数字格式错误,如使用逗号作为千位分隔符或包含非法字符。
json复制代码// 无效的 JSON  
{  "price": 1,000.50  
}  // 有效的 JSON  
{  "price": 1000.5  
}
  1. 使用了 JavaScript 的特殊值,如 undefined、function 或 NaN,这些都是 JSON 不支持的。
json复制代码// 无效的 JSON(尝试包含 JavaScript 类型的值)  
{  "value": undefined  
}  // 有效的 JSON(使用 null 表示空值)  
{  "value": null  
}
  1. 对象或数组的键名不是有效的字符串。
json复制代码// 无效的 JSON(键名不是字符串)  
{  age: 30  
}  // 有效的 JSON(键名是字符串)  
{  "age": 30  
}

如果您尝试解析一个无效的 JSON 字符串,您应该使用 try...catch 语句来捕获 SyntaxError 并适当地处理它。例如:

javascript复制代码const jsonString = '{ name: "John" }'; // 无效的 JSON  try {  const obj = JSON.parse(jsonString);  console.log(obj);  
} catch (error) {  console.error('JSON 解析错误:', error);  
}

在上面的示例中,因为 jsonString 是一个无效的 JSON 字符串,所以 JSON.parse() 会抛出一个 SyntaxError,该错误会被 catch 语句捕获并打印到控制台。


http://www.ppmy.cn/news/1453418.html

相关文章

R语言之如何安装R和RStudio软件

目录 简介下载R安装包安装R软件安装RStudio软件总结 简介 R软件是一种用于统计计算和数据分析的编程语言,它提供了丰富的函数和包来处理和分析各种数据集。R具有广泛的应用领域,包括统计学、生物信息学、金融学等。它是一个开源,免费的软件。…

java:EasyExcel使用(一)读excel

java:EasyExcel使用(一)读excel 1 前言 EasyExcel相比于传统使用poi进行excel文件读写,编程使用操作上更加方便快捷,且对于内存溢出进行了优化处理。本文是EasyExcel读excel操作。 Java解析、生成Excel比较有名的框…

my-room-in-3d中的电脑,电视,桌面光带发光原理

1. my-room-in-3d中的电脑,电视,桌面光带发光原理 最近在github中,看到了这样的一个项目; 项目地址 我看到的时候,蛮好奇他这个光带时怎么做的。 最后发现,他是通过,加载一个 lightMap.jpg这个…

深入浅出 BERT

Transformer 用于学习句子中的长距离依赖关系,同时执行序列到序列的建模。 它通过解决可变长度输入、并行化、梯度消失或爆炸、数据规模巨大等问题,比其他模型表现更好。使用的注意力机制是神经架构的一部分,使其能够动态突出显示输入数据的…

【阿里云服务器】ubuntu 22.04.1安装docker以及部署java环境

我的服务器配置是2GB CPU 2GB 内存 Ubuntu22.04 目录 一、阿里云 ubuntu 22.04.1安装docker 二、docker基础命令 三、Windows电脑访问云服务器 四、安装java环境 安装OpenJDK 8(可以根据需要安装其他版本的JDK) 安装java的依赖管理工具maven 一、…

消息队列相关汇总

目录 一、什么是消息队列 二、Kafka怎么避免重复消费 三、RabbitMQ 的消息如何实现路由 四、如何保证RabbitMQ的消息可靠传输 五、如何进⾏消息队列选型 一、什么是消息队列 消息队列 Message Queue,简称 MQ。是一种应用间的通信方式,主要由三个部分…

2024-04-29 问AI: 介绍一下 TensorFlow Hub

文心一言 TensorFlow Hub是一个在TensorFlow中发布和重用机器学习模块的平台。它包含各种预训练模型的综合代码库,这些模型稍作调整便可部署到任何设备上。TensorFlow Hub的基本思想是,用一个现成的图像识别模块从图像中提取特征训练一个新的分类器。Te…

Qt QLCDNumber详解

1.简介 它提供了一个显示数字的显示屏控件,效果类似于现实世界中的液晶显示屏。它可以显示任何大小的数字。它可以显示十进制、十六进制、八进制或二进制数字。可以用setMode更改基数,用setSmallDecimalPoint更改小数点。 2.常用方法 以下是一些常用的…