解锁JSON的奇妙世界:从基础到高级应用,一文搞懂JSON的妙用(上)

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
简介: 解锁JSON的奇妙世界:从基础到高级应用,一文搞懂JSON的妙用(上)

JSON(JavaScript Object Notation)作为一种轻量级的数据交换格式,不仅易于人阅读和编写,还易于机器解析和生成。本文深入探讨了JSON的基本特点,从简单的数据格式到支持的数据类型,再到嵌套结构、处理日期、数组和特殊值等高级用法。通过实例演示,展示了JSON在前后端数据交换中的常见应用,以及在处理复杂数据结构、日期、数组等方面的技巧。此外,还介绍了一些高级应用,如使用JSON Web Token (JWT)进行身份验证,处理JSONP跨域请求,使用JSONPath查询节点,以及利用JSON Server快速搭建虚拟API。通过深入理解这些应用,开发者可以更灵活地运用JSON,提高开发效率。

它基于键值对的方式组织数据,具有以下几个特点

JSON的特点

  1. 数据格式简单: JSON 数据只包含键值对,键和值之间使用冒号分隔,键值对之间使用逗号分隔。数据由对象和数组组成。
{
  "name": "John",
  "age": 30,
  "city": "New York",
  "isStudent": false,
  "grades": [85, 92, 78]
}
  1. 数据类型:JSON 支持字符串、数字、布尔值、数组、对象、null 这几种数据类型。
  • 字符串:使用双引号包裹的 Unicode 字符串。
  • 数字:整数或浮点数。
  • 布尔值:true 或 false。
  • 数组:有序的值列表,使用方括号包裹。
  • 对象:无序的键值对集合,使用花括号包裹。
  • null:表示空值。
  1. 易于嵌套: 可以嵌套使用对象和数组,形成复杂的数据结构。
{
  "person": {
    "name": "Alice",
    "age": 25,
    "address": {
      "city": "London",
      "postalCode": "SW1A 1AA"
    }
  },
  "hobbies": ["reading", "traveling"]
}
  1. 键值对的无序性: JSON 对象中的键值对没有固定的顺序,但大多数 JSON 解析器会保持读取时的顺序。
  2. 可读性和可扩展性: JSON 数据是纯文本,易于人类阅读和编写。它还支持嵌套结构,可以轻松地扩展为更复杂的数据模型。

JSON 通常用于在前后端之间进行数据交换,也经常用于配置文件和日志文件等场景。在 JavaScript 中,可以使用 JSON.parse() 方法将 JSON 字符串解析为 JavaScript 对象,而 JSON.stringify() 方法则用于将 JavaScript 对象序列化为 JSON 字符串。

总体而言,JSON 是一种通用的数据交换格式,由于其简单性和可读性,成为许多应用程序和服务之间常用的数据格式。

当使用 JSON 时,最常见的情况之一是在前端和后端之间进行数据交换。以下是一个简单的 JSON 使用实例,其中包括将 JavaScript 对象转换为 JSON 字符串以及将 JSON 字符串解析为 JavaScript 对象的过程:

JSON 转字符串

假设有一个 JavaScript 对象表示用户信息:

const user = {
  "id": 123,
  "username": "john_doe",
  "email": "john@example.com",
  "isPremiumUser": true,
  "roles": ["user", "admin"]
};

要将该对象转换为 JSON 字符串,可以使用 JSON.stringify() 方法:

const jsonString = JSON.stringify(user);
console.log(jsonString);

上述代码会输出如下 JSON 字符串:

{
  "id": 123,
  "username": "john_doe",
  "email": "john@example.com",
  "isPremiumUser": true,
  "roles": ["user", "admin"]
}

字符串解析为 JSON

反过来,如果有一个 JSON 字符串,可以使用 JSON.parse() 方法将其解析为 JavaScript 对象:

const jsonString = '{"id":123,"username":"john_doe","email":"john@example.com","isPremiumUser":true,"roles":["user","admin"]}';
const parsedUser = JSON.parse(jsonString);
console.log(parsedUser);

上述代码会输出如下 JavaScript 对象:

{
  id: 123,
  username: 'john_doe',
  email: 'john@example.com',
  isPremiumUser: true,
  roles: ['user', 'admin']
}

这两个过程是在前后端交互中非常常见的步骤。前端通常会将用户输入的数据转换为 JSON 字符串,然后通过网络传递给后端。后端接收到 JSON 字符串后,使用 JSON.parse() 转换为对象,进行进一步的处理和存储。

这只是 JSON 在实际应用中的一个简单示例,实际场景可能涉及更复杂的数据结构和交互。

当使用 JSON 时,除了基本的对象转换和解析,还可以考虑一些其他常见的用例。以下是一些 JSON 的高级用法和实例:

1. 处理嵌套结构

JSON 支持嵌套结构,例如一个用户对象中包含地址信息:

const userWithAddress = {
  "id": 123,
  "username": "john_doe",
  "address": {
    "street": "123 Main St",
    "city": "Anytown",
    "zipcode": "12345"
  }
};

2. 处理日期

在 JSON 中,日期通常以字符串的形式表示。例如,一个包含日期的事件对象:

const event = {
  "name": "Birthday Party",
  "date": "2024-02-01T18:30:00.000Z"
};

3. 处理数组

JSON 中的数组允许存储多个相似类型的元素:

const shoppingList = {
  "items": [
    {"name": "Milk", "quantity": 2},
    {"name": "Bread", "quantity": 1},
    {"name": "Eggs", "quantity": 12}
  ]
};
• 1
• 2
• 3
• 4
• 5
• 6
• 7

4. 处理特殊值

JSON 支持常见的特殊值,如 null

const data = {
  "value": null
};

5. 处理 JSON Schema

JSON Schema 是一种描述 JSON 数据结构的标准。以下是一个简单的 JSON Schema 示例:

{
  "$schema": "http://json-schema.org/draft-07/schema#",
  "type": "object",
  "properties": {
    "name": {
      "type": "string"
    },
    "age": {
      "type": "integer"
    },
    "email": {
      "type": "string",
      "format": "email"
    }
  },
  "required": ["name"]
}

这个 JSON Schema 描述了一个包含姓名(必须)、年龄(整数类型)、电子邮件(符合电子邮件格式)的对象。

6. 使用 Fetch API 发送 JSON 数据

在前端,使用 Fetch API 可以方便地发送 JSON 数据。以下是一个使用 Fetch 发送 POST 请求的例子:

const user = {
  "username": "john_doe",
  "email": "john@example.com"
};
fetch('https://example.com/api/users', {
  method: 'POST',
  headers: {
    'Content-Type': 'application/json'
  },
  body: JSON.stringify(user)
})
  .then(response => response.json())
  .then(data => console.log(data))
  .catch(error => console.error('Error:', error));

这是一些在实际应用中可能遇到的 JSON 使用实例。JSON 在数据交换和存储中被广泛使用,其简单性和易读性使其成为理想的数据格式之一。

当使用 JSON 时,还有一些其他用例和技巧,具体取决于具体的应用场景。以下是一些建议:

7. 使用 JSON Web Token (JWT)

JWT 是一种基于 JSON 的开放标准(RFC 7519),用于在各方之间安全地传输信息。它通常用于身份验证和信息交换。以下是一个简单的 JWT 示例:

const jwt = require('jsonwebtoken');
const secretKey = 'mySecretKey';
const payload = {
  userId: 123,
  username: 'john_doe'
};
const token = jwt.sign(payload, secretKey);
console.log('JWT:', token);

8. 处理 JSONP


JSONP 是一种通过动态创建 <script> 标签来加载跨域 JSON 数据的技术。以下是一个 JSONP 请求的简单例子:

function handleResponse(data) {
  console.log('JSONP Response:', data);
}
const script = document.createElement('script');
script.src = 'https://example.com/api/data?callback=handleResponse';
document.head.appendChild(script);

9. 使用 JSONPath

JSONPath 是一种用于从 JSON 数据中选择或查询节点的语言。类似于 XPath 对 XML 的作用。以下是一个简单的 JSONPath 查询示例:

const jsonPath = require('jsonpath');
const data = {
  "store": {
    "book": [
      {"title": "Book 1", "price": 20},
      {"title": "Book 2", "price": 25}
    ],
    "location": "New York"
  }
};
const prices = jsonPath.query(data, '$.store.book[*].price');
console.log('Book Prices:', prices);

10. 使用 JSON Server

JSON Server 是一个轻量级的 RESTful API 服务器,可基于 JSON 文件快速搭建虚拟 API。以下是一个使用 JSON Server 的例子:

# 全局安装 JSON Server
npm install -g json-server
# 创建一个包含数据的 JSON 文件(db.json)
# 启动 JSON Server
json-server --watch db.json

这些是一些建议,覆盖了一些更高级的 JSON 使用情景和相关工具。JSON 在各种开发场景中都有着广泛的应用,因此深入了解它的各个方面可以为开发者提供更多的灵活性和效率。

相关文章
|
8月前
|
存储 JSON NoSQL
解锁JSON的奇妙世界:从基础到高级应用,一文搞懂JSON的妙用(下)
解锁JSON的奇妙世界:从基础到高级应用,一文搞懂JSON的妙用(下)
241 0
|
2天前
|
JSON 小程序 UED
微信小程序 app.json 配置文件解析与应用
本文介绍了微信小程序中 `app.json` 配置文件的详细
36 12
|
7月前
|
JSON 数据处理 数据安全/隐私保护
Ktor库的高级用法:代理服务器与JSON处理
Ktor库的高级用法:代理服务器与JSON处理
|
2月前
|
存储 JSON 监控
公司用什么软件监控电脑:JSON 在监控信息交互中的应用探索
在现代企业管理中,电脑监控软件广泛应用于保障信息安全和提升工作效率。JSON(JavaScript Object Notation)因其简洁和易读性,在监控信息的收集、传输和处理中扮演着关键角色。本文介绍了 JSON 在监控数据结构、信息传输及服务器端处理中的具体应用,展示了其在高效监控系统中的重要性。
43 0
|
5月前
|
存储 SQL JSON
【Azure Logic App】微软云逻辑应用连接到数据库,执行存储过程并转换执行结果为JSON数据
【Azure Logic App】微软云逻辑应用连接到数据库,执行存储过程并转换执行结果为JSON数据
【Azure Logic App】微软云逻辑应用连接到数据库,执行存储过程并转换执行结果为JSON数据
|
5月前
|
JSON Java Android开发
Android 开发者必备秘籍:轻松攻克 JSON 格式数据解析难题,让你的应用更出色!
【8月更文挑战第18天】在Android开发中,解析JSON数据至关重要。JSON以其简洁和易读成为首选的数据交换格式。开发者可通过多种途径解析JSON,如使用内置的`JSONObject`和`JSONArray`类直接操作数据,或借助Google提供的Gson库将JSON自动映射为Java对象。无论哪种方法,正确解析JSON都是实现高效应用的关键,能帮助开发者处理网络请求返回的数据,并将其展示给用户,从而提升应用的功能性和用户体验。
126 1
|
5月前
|
JSON 数据格式 Java
化繁为简的魔法:Struts 2 与 JSON 联手打造超流畅数据交换体验,让应用飞起来!
【8月更文挑战第31天】在现代 Web 开发中,JSON 成为数据交换的主流格式,以其轻量、易读和易解析的特点受到青睐。Struts 2 内置对 JSON 的支持,结合 Jackson 库可便捷实现数据传输。本文通过具体示例展示了如何在 Struts 2 中进行 JSON 数据的序列化与反序列化,并结合 AJAX 技术提升 Web 应用的响应速度和用户体验。
155 0
|
7月前
|
存储 JSON 关系型数据库
MySQL JSON 类型:功能与应用
MySQL JSON 类型:功能与应用
|
8月前
|
XML JSON API
转Android上基于JSON的数据交互应用
转Android上基于JSON的数据交互应用
56 1
|
8月前
|
JSON 编译器 Go
Golang深入浅出之-结构体标签(Tags):JSON序列化与反射应用
【4月更文挑战第22天】Go语言结构体标签用于添加元信息,常用于JSON序列化和ORM框架。本文聚焦JSON序列化和反射应用,讨论了如何使用`json`标签处理敏感字段、实现`omitempty`、自定义字段名和嵌套结构体。同时,通过反射访问标签信息,但应注意反射可能带来的性能问题。正确使用结构体标签能提升代码质量和安全性。
364 0