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

news2024/11/24 8:15:24

在这里插入图片描述

🤍 前端开发工程师(主业)、技术博主(副业)、已过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.coloradmin.cn/o/1287856.html

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

相关文章

《微信小程序开发从入门到实战》学习四十一

4.3 云开发文件存储 文件存储功能支持将任意数量和格式的文件(如图片和视频)保存在云端,支持 以文件夹的形式将文件归类。 在云开发控制台中,可以对云端保存的文件进行管理。 也可以通过文件存储API对文件进行上传、删除、移动…

Android Chips(标签)

目录 一、流式布局标签发展历程 二、类型及使用 2.1 Chip.Action(默认值) 2.2 Chip.Entry 2.3 Chip.Filter 2.4 Chip.Choice 三、常用事件 3.1 OnClickListener 3.2 OnCheckedChangeListener 3.3 OnCloseIconClickListener 四、ChipGroup 4.1 ChipGroup Chip.Choi…

java开发神器之ecplise的基本使用

java开发神器之ecplise的基本使用 一、ecplise的安装二、利用ecplise创建工作空间 一、ecplise的安装 免安装eclipse程序包 二、利用ecplise创建工作空间 1、准备好eclipse的程序包,右键执行程序。 2、若打开eclipse显示如下第一张图的界面提示,是因…

leetcode 1004. 最大连续1的个数 III(优质解法)

代码&#xff1a; class Solution {public int longestOnes(int[] nums, int k) {int lengthnums.length;int zero0; //计数器&#xff0c;计数翻转 0 的个数int max0; //记录当前获得的最长子数组长度for(int left0,right0;right<length;right){if(nums[right]0){zero;wh…

scipy笔记:scipy.interpolate.interp1d

1 主要使用方法 class scipy.interpolate.interp1d(x, y, kindlinear, axis-1, copyTrue, bounds_errorNone, fill_valuenan, assume_sortedFalse) 2 主要函数 x一维实数值数组&#xff0c;代表插值的自变量y N维实数值数组&#xff0c;其中沿着插值轴的 y 长度必须等于 x 的…

根文件系统的开机自启动测试

一. 简介 本文在之前制作的根文件系统可以正常运行的基础上进行的&#xff0c;继上一篇文章地址如下&#xff1a; 完善根文件系统-CSDN博客 在前面测试软件hello 运行时&#xff0c;都是等 Linux 启动进入根文件系统以后手动输入 “./hello” 命令 来完成的。 我们一般做好产…

<Linux>(极简关键、省时省力)《Linux操作系统原理分析之文件管理(2)》(23)

《Linux操作系统原理分析之文件管理&#xff08;2&#xff09;》&#xff08;23&#xff09; 7 文件管理7.3 文件的目录结构7.3.1 文件说明、目录文件7.3.2 文件目录结构 7.4 文件存取与操作 7 文件管理 7.3 文件的目录结构 7.3.1 文件说明、目录文件 文件说明 FCB&#xff…

dockerdesktop 制作asp.net core webapi镜像-连接sqlserver数据库容器

1.使用visual studio 创建 asp.net core webapi项目 选择启用docker 会生成Dockerfile文件 2.使用efcore连接数据库&#xff0c;安装efcore的包 <ItemGroup><PackageReference Include"Microsoft.VisualStudio.Azure.Containers.Tools.Targets" Version&qu…

如何配置WinDbg和VMware实现内核的调试

设置 VMware 的虚拟串口 运行 VMware&#xff0c;首先将 Guest OS 系统电源关闭&#xff0c;这样才能修改该系统的虚拟机设置。 单击界面上的“编辑虚拟机设置”选项对虚拟机的属性进行设置。 单击“添加”按钮&#xff0c;打开 VMware 的 添加硬件向导 对话框 选择“串行端口…

第17章 匿名函数

第17.1节 匿名函数的基本语法 [捕获列表](参数列表) mutable(可选) 异常属性 -> 返回类型 { // 函数体 }语法规则&#xff1a;lambda表达式可以看成是一般函数的函数名被略去&#xff0c;返回值使用了一个 -> 的形式表示。唯一与普通函数不同的是增加了“捕获列表”。 …

Python 调用企业微信群机器人发送消息及文件

Python 操作企业微信群机器人。 企业微信群创建机器人 &#xff1a; 安装 requests json &#xff1a; pip install requests pip install json发送消息&#xff08;markdown&#xff09; import requests import json# 企业微信机器人发送文字 def send_markdown (message, …

7.Vue UI库

7.Vue UI库 7.1移动端常用的UI库 &#xff08;1&#xff09; Vant&#xff1a;Vant 4 - A lightweight, customizable Vue UI library for mobile web apps.A lightweight, customizable Vue UI library for mobile web apps.https://vant-ui.github.io/vant/#/zh-CN &#xf…

分类预测 | Matlab实现OOA-CNN-SVM鱼鹰算法优化卷积支持向量机分类预测

分类预测 | Matlab实现OOA-CNN-SVM鱼鹰算法优化卷积支持向量机分类预测 目录 分类预测 | Matlab实现OOA-CNN-SVM鱼鹰算法优化卷积支持向量机分类预测分类效果基本描述程序设计参考资料 分类效果 基本描述 1.Matlab实现OOA-CNN-SVM鱼鹰算法优化卷积支持向量机分类预测&#xff0…

在AWS CodeBuild中更新Lambda导致进程被占用(status error 255)的解决方案

大纲 1 问题描述1.1 错误提示1.2 错误分析和解决方案 2 解决方法2.1 YMAL文件样例 参考文献 1 问题描述 在Lambda的部署实践中&#xff0c;我们尝试使用CodeBuild将代码更新到Lambda函数中。在这个过程中&#xff0c;偶尔会触发一个不太常见的状态&#xff1a;Lambda状态一直是…

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

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

IDEA版SSM入门到实战(Maven+MyBatis+Spring+SpringMVC) -Mybatis核心配置详解

第一章 Mybatis核心配置详解【mybatis-config.xml】 1.1 核心配置文件概述 MyBatis 的配置文件包含了会深深影响 MyBatis 行为的设置和属性信息。 1.2 核心配置文件根标签 没有实际语义&#xff0c;主要作用&#xff1a;所有子标签均需要设置在跟标签内部 1.3 核心配置文件…

设计模式之结构型模式(适配器、桥接、组合、享元、装饰者、外观、代理)

文章目录 一、结构型设计模式二、适配器模式三、桥接模式四、组合模式五、享元模式六、装饰者模式七、外观模式八、代理设计模式 一、结构型设计模式 这篇文章我们来讲解下结构型设计模式&#xff0c;结构型设计模式&#xff0c;主要处理类或对象的组合关系&#xff0c;为如何…

中文手写数字数据识别

实验环境 python3.7torch1.13.1cu117 torchaudio0.13.1cu117 torchvision0.14.1数据下载地址&#xff1a;Mnist中文手写数字数据集Python资源-CSDN文库 这些汉字包括&#xff1a; 零、一、二、三、四、五、六、七、八、九、十、百、千、万、亿 总共15个汉字&#xff0c;分别…

HarmonyOS学习--了解基本工程目录

1.工程级目录 工程的目录结构如下&#xff1a; 其中详细如下&#xff1a; AppScope中存放应用全局所需要的资源文件。entry是应用的主模块&#xff0c;存放HarmonyOS应用的代码、资源等。oh_modules是工程的依赖包&#xff0c;存放工程依赖的源文件。build-profile.json5是工…

Scrapy爬虫数据存储为JSON文件的解决方案

什么是JSON文件 JSON&#xff08;JavaScript Object Notation&#xff09;是一种轻量级的数据交换格式&#xff0c;易于人们阅读和编写&#xff0c;同时也易于机器解析和生成。它基于JavaScript Spark语言的一个子集&#xff0c;但独立于Smashing语言&#xff0c;因此在许多中…