JSON 语法详解:轻松掌握数据结构(上)

在这里插入图片描述

🤍 前端开发工程师(主业)、技术博主(副业)、已过CET6
🍨 阿珊和她的猫_CSDN个人主页
🕠 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》
🍚 蓝桥云课签约作者、已在蓝桥云课上架的前后端实战课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入门到实战全面掌握 uni-app》

文章目录

  • 1. 什么是 JSON?
    • JSON 的定义和特点
    • JSON 与其他数据格式的比较
  • 2. JSON 的语法
    • 数据结构:对象、数组、字符串、数字、布尔值、 null
    • 键值对的表示
    • 数组的表示
  • 3. JSON 的解析和生成
    • 使用 JavaScript 解析和生成 JSON

1. 什么是 JSON?

JSON 的定义和特点

  1. JSON 的定义:JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,它基于 JavaScript 对象表示法(JavaScript Object Notation),常用于 Web 开发中。
  2. JSON 的特点:
  • 轻量级:JSON 格式简单,易于阅读和编写,并且占用的存储空间较小
  • 跨平台:JSON 是一种跨平台的数据格式,可以在不同的编程语言和系统之间进行数据交换。
  • 易于解析:JSON 格式易于解析,可以使用各种编程语言中的标准库或第三方库来解析 JSON 数据。
  • 支持嵌套:JSON 支持嵌套结构,可以表示复杂的数据结构,如数组、对象等。
  • 可扩展性:JSON 可以根据需要进行扩展,添加自定义的属性或方法。

在这里插入图片描述

总的来说,JSON 是一种简洁、灵活、易于使用的数据交换格式,在 Web 开发中得到了广泛的应用。

JSON 与其他数据格式的比较

以下是 JSON 与其他数据格式的比较,使用表格的形式进行详细的解释和说明:

数据格式JSONXMLYAML
定义JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,基于 JavaScript 对象表示法XML(Extensible Markup Language)是一种可扩展的标记语言,用于存储和交换结构化数据YAML(YAML Ain’t Markup Language)是一种人类可读的数据序列化语言
特点轻量级、跨平台、易于解析、支持嵌套、可扩展性可扩展性、自定义性强、适用于大规模数据存储和交换简洁、易于阅读、适用于配置文件和数据存储
语法使用键值对表示数据,值可以是字符串、数字、对象、数组等使用标记和属性来描述数据,标记用于定义数据的类型和结构使用缩进和冒号表示数据的层次结构,类似于 Python 语法
可读性简洁、易于阅读和理解相对复杂,需要理解标记和属性的含义简洁、易于阅读和理解
可扩展性支持自定义属性和方法,可以根据需要进行扩展可扩展性强,可以自定义标记和属性可扩展性较弱,不支持自定义数据类型
应用场景Web 开发、移动应用开发、数据交换、配置文件等大规模数据存储和交换、企业级应用、SOAP 协议等配置文件、数据存储、自动化任务等

需要注意的是,每种数据格式都有其优缺点和适用场景,具体使用哪种数据格式取决于项目的需求和技术栈。在选择数据格式时,需要考虑数据的大小、可读性、可扩展性、解析性能等因素。

2. JSON 的语法

数据结构:对象、数组、字符串、数字、布尔值、 null

JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,它的语法基于 JavaScript 对象的表示形式。

JSON 数据结构包括以下几种类型:

  1. 对象(Object):对象是由键值对组成的无序集合。键是一个字符串,值可以是字符串、数字、布尔值、对象、数组或 null。对象用花括号"{ }“表示,键值对用冒号”:"分隔,键与值用逗号,分隔。
  2. 数组(Array):数组是一组有序的元素列表。数组用方括号"[ ]"表示,元素之间用逗号,分隔。
  3. 字符串(String):字符串是由双引号" "括起来的一系列字符。可以使用转义字符来表示特殊字符。
  4. 数字(Number):数字可以是整数或浮点数。整数可以是十进制、八进制(以"0"开头)或十六进制(以"0x"开头)。浮点数可以使用科学计数法表示。
  5. 布尔值(Boolean):布尔值只有两个值:true(表示真)或 false(表示假)。
  6. nullnull 表示空值或未定义的值

以下是一个 JSON 示例:

{"name": "John Doe","age": 30,"isStudent": true,"subjects": ["数学", "计算机科学"]
}

在这个示例中,“name”、“age”、"isStudent"和"subjects"是对象的键,它们的值分别是字符串、数字、布尔值和数组。

键值对的表示

在 JSON 中,键值对是通过对象表示的。对象是由花括号"{ }“括起来的一组键值对,键与值之间用冒号”:"分隔,键与值用逗号,分隔。键是一个字符串,值可以是字符串、数字、布尔值、对象、数组或 null。

以下是一个 JSON 对象的示例:

{"name": "John Doe","age": 30,"isStudent": true,"subjects": ["数学", "计算机科学"]
}

在这个示例中,“name”、“age”、"isStudent"和"subjects"是对象的键,它们的值分别是字符串、数字、布尔值和数组。

数组的表示

在 JSON 中,数组是通过方括号"[ ]"表示的。数组是一组有序的元素列表,元素之间用逗号,分隔。

以下是一个 JSON 数组的示例:

["数学", "计算机科学", "物理"]

在这个示例中,“数学”、"计算机科学"和"物理"是数组的元素,它们都是字符串类型。数组可以包含不同类型的元素,包括字符串、数字、布尔值、对象或数组。

3. JSON 的解析和生成

使用 JavaScript 解析和生成 JSON

在 JavaScript 中,我们可以使用 JSON.parse()方法来解析 JSON 字符串,并将其转换为 JavaScript 对象。我们也可以使用 JSON.stringify()方法将 JavaScript 对象转换为 JSON 字符串。

以下是使用 JavaScript 解析和生成 JSON 的示例代码:

解析 JSON 字符串:

let jsonString = '{"name": "John Doe", "age": 30, "isStudent": true, "subjects": ["数学", "计算机科学"]}';let jsonObject = JSON.parse(jsonString);console.log(jsonObject); // 输出:{ name: 'John Doe', age: 30, isStudent: true, subjects: [ '数学', '计算机科学' ] }

在这个示例中,我们首先定义了一个 JSON 字符串 jsonString,然后使用 JSON.parse()方法将其解析为 JavaScript 对象 jsonObject。最后,我们使用 console.log()方法输出解析后的对象。

生成 JSON 字符串:

let person = { name: "John Doe", age: 30, isStudent: true, subjects: ["数学", "计算机科学"] };let jsonString = JSON.stringify(person);console.log(jsonString); // 输出:{"name":"John Doe","age":30,"isStudent":true,"subjects":["数学","计算机科学"]}

在这个示例中,我们首先定义了一个 JavaScript 对象 person,然后使用 JSON.stringify()方法将其转换为 JSON 字符串 jsonString。最后,我们使用 console.log()方法输出生成的 JSON 字符串。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/200579.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

postgresql-effective_cache_size参数详解

在 PostgreSQL 中,effective_cache_size 是一个配置参数,用于告诉查询规划器关于系统中可用缓存的估计信息。这个参数并不表示实际的内存量,而是用于告诉 PostgreSQL 查询规划器系统中可用的磁盘缓存和操作系统级别的文件系统缓存的大小。它用…

Lambda表达式用法汇总

Lambda表达式用法汇总 java8 中引入的 Lambda 表达式真的是个好东西,掌握之后,写代码更简洁了,码字效率也提升了不少,这里咱 们一起来看看 Lambada 表达式常见的写法,加深理解。 1、有参无返回值函数式接口 8 种写法…

【代码随想录】算法训练计划39

dp 1、62. 不同路径 题目: 求路径方案多少个 思路: 这道题就有点dp了哈 func uniquePaths(m int, n int) int {//dp,写过,代表的是多少种// 初始化dp : make([][]int, m)for i : range dp {dp[i] make([]int, n)dp[i][0] 1 // 代表到…

用友NC Cloud FileParserServlet反序列化RCE漏洞复现

0x01 产品简介 用友 NC Cloud 是一种商业级的企业资源规划云平台,为企业提供全面的管理解决方案,包括财务管理、采购管理、销售管理、人力资源管理等功能,实现企业的数字化转型和业务流程优化。 0x02 漏洞概述 用友 NC Cloud FileParserServlet接口存在反序列化代码执行漏…

response应用

文章目录 [TOC](文章目录) response说明一、response文件下载二、待补充。。。 response说明 response是指HttpServletResponse,该响应有很多的应用,比如像浏览器输出消息,下载文件,实现验证码等。 一、response文件下载 1.创建一个javaw…

springboot整合swagger

1)简介: 作为后端开放人员,最烦的事就是自己写接口文档和别人没有写接口文档,不管是前端还是后端开发,多多少少都会被接口文档所折磨,前端会抱怨后端没有及时更新接口文档,而后端又会觉得编写接…

Spark-03: Spark SQL 基础编程

目录 1.Spark SQL 简介 2.SparkSession 3.Spark SQL 数据的读写 3.1 读写 TXT 文件 3.2 读写 CSV 文件 3.3 读写 JSON 文件 3.4 读写 Parquet 文件 3.5 读写 ORC 文件 3.6 读写MySQL数据库 4.Spark SQL 语法 4.1 SQL 语法 4.2 DSL 语法 1.Spark SQL 简介 Spark SQL…

备份和恢复Linux服务器上的HTTP配置

备份和恢复Linux服务器上的HTTP配置是一项重要的任务,它可以确保您的服务器在出现故障或配置错误时能够迅速恢复正常运行。下面我们将介绍如何备份和恢复Linux服务器上的HTTP配置。 备份HTTP配置 登录到Linux服务器上,并使用root权限。 备份HTTP配置文…

分部积分法

1.形式:u对v求积分uv-v对u求积分,一前一后,一般把三角函数,反三角函数,In,e的x次方提到d里面 2. 3. 4. 5. 6. 7. 当结果中出现要求的不要慌,不是1直接求,是1重新计算

一体化污水处理设备材质怎么选

在环保意识日益增强的今天,污水处理设备成为城市建设过程中的重要环节。而选择合适的一体化污水处理设备材质,则成为了一项重要的决策。本文将从专业的角度出发,为您解析一体化污水处理设备材质的选取。 首先,一体化污水处理设备材…

postman常用脚本

在参数中动态添加开始时间和结束时间的时间戳 1.先在collection中添加参数,这里的作用域是collection,也可以是其他的任何scope 2.在Pre-request Script 中设定开始时间和结束时间参数,比如昨天和今天的时间戳,下面是js代码 con…

Android Studio Hedgehog | 2023.1.1(刺猬)

Android Gradle 插件和 Android Studio 兼容性 Android Studio 构建系统基于 Gradle,并且 Android Gradle 插件 (AGP) 添加了一些特定于构建 Android 应用程序的功能。下表列出了每个版本的 Android Studio 所需的 AGP 版本。 Android Studio versionRequired AG…

Kubernetes 常用命令

集群信息&#xff1a; 1. 显示 Kubernetes 版本&#xff1a;kubectl version2. 显示集群信息&#xff1a;kubectl cluster-info3. 列出集群中的所有节点&#xff1a;kubectl get nodes4. 查看一个具体的节点详情&#xff1a;kubectl describe node <node-name>5. 列出所…

python学习:opencv+用鼠标画矩形和圆形

目录 步骤 定义数据 新建一个窗口黑色画布 显示黑色画布 添加鼠标回调函数 循环 一直显示图片 一直判断有没有按下字母 m 关闭所有窗口 鼠标回调函数 步骤 当鼠标按下记录坐标并记录鼠标标记位为true&#xff0c;移动的时候就会不断的画矩形或者圆&#xff0c;松下的时候就再…

vue项目通过宝塔部署之后,页面刷新后浏览器404页面

转载&#xff1a;vue项目通过宝塔部署之后&#xff0c;页面刷新后浏览器404页面。

ioc循环依赖怎么解决

在使用IoC&#xff08;Inversion of Control&#xff09;容器时&#xff0c;循环依赖是一个常见的问题。不同的IoC容器提供了不同的解决方案。在Spring框架中&#xff0c;常用的解决循环依赖的注解是 Lazy 和 Autowired。 1.Lazy 注解&#xff1a; 在Spring中&#xff0c;Lazy…

STM32F1中断NVIC

目录 1. 中断系统 2. 中断向量表 3. NVIC基本结构 4. NVIC优先级分组 5. NVIC程序编写 5.1 中断分组 5.2 中断结构体变量 5.3 中断通道选择 5.4 抢占优先级和响应优先级配置 6. 中断程序执行 1. 中断系统 中断&#xff1a;在主程序运行过程中&#xff0…

如何设计自动化测试脚本

企业中如何设计自动化测试脚本呢&#xff1f;今天我们就来为大家分享一些干货。 一、线性设计 线性脚本设计方式是以脚本的方式体现测试用例&#xff0c;是一种非结构化的编码方式&#xff0c;多数采用录制回放的方式&#xff0c;测试工程师通过录制回访的访问对被测系统进行…

基于JSDoc实现TypeScript类型安全的实践报告

在FEDay 2023中我讲了《从JS到TS无缝迁移的实践报告》【视频在这里在这里】&#xff0c;是将一个传统的JS项目&#xff08;mochajs/mocha&#xff09;迁移到TypeScript环境的全程。其中提到了一件事情&#xff0c;就是“可以通过JSDoc/TSDoc来生成.d.ts”&#xff0c;从而实现T…

FastAPI的路由

前言 回想一下我们在hello world程序里面做了哪些事情&#xff1f; 还是先把那段著名的程序的代码贴出来欣赏一下吧。 from fastapi import FastAPIapp FastAPI()app.get("/") async def root():return {"message": "Hello World"}app.get(&q…