JSON 简述与应用

1. JSON 简述

        JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,常用于客户端与服务器之间的数据传递。它基于JavaScript对象表示法,但独立于语言,可以被多种编程语言解析和生成。

1.1 特点

        轻量级:相比于XML,JSON更简洁,数据体积更小。

        易读性:结构清晰,易于人类阅读和编写。

        易解析:解析和生成速度快,广泛支持于各种编程语言。

        可嵌套:JSON支持嵌套数据结构,可以表示复杂的数据模型。

2. XML 与 JSON 的区别

2.1 格式

        JSON 是基于键值对的简单格式。

        XML 是基于标签的复杂格式。

2.2 体积

        JSON 数据通常比 XML 更小,传输速度更快。

        XML 数据冗余信息较多,传输速度较慢。

2.3 可读性

        JSON 结构清晰,易读性强。

        XML 标签繁多,嵌套复杂,较难阅读。

2.4 解析

        JSON 解析速度快,容易解析。

        XML 解析需要解析器,速度较慢。

2.5 用途

        JSON 常用于客户端和服务器之间的数据传输。

        XML 常用于配置文件和文档格式的描述。

2.6 扩展性

        JSON 相对简单,不支持复杂的数据类型。

        XML 支持属性、命名空间等复杂数据表示。

3. JSON 语法格式

3.1 JSON 语法介绍

        JSON 使用键值对来表示数据,并且支持以下几种数据类型:

        数字(整数或浮点数)

        字符串(用双引号括起来)

        布尔值(true 或 false)

        数组(有序的值列表)

        对象(键值对的集合)

        null(空值)

3.2 JSON 语法规则

        对象:由花括号 `{}` 包围,包含零个或多个键值对。键和值之间用冒号 `:` 分隔,键值对之间用逗号 `,` 分隔。

        数组:由方括号 `[]` 包围,包含零个或多个值,值之间用逗号 `,` 分隔。

        字符串:使用双引号 `"` 括起来,支持转义字符(如 `\n`、`\t` 等)。

        数字:可以是整数或浮点数,不使用引号括起来。

        布尔值:true 或 false,不使用引号括起来。

        null:表示空值,不使用引号括起来。

3.3 JSON 语法示例

        一个典型的 JSON 对象如下所示:

{

    "name": "Alice",

    "age": 30,

    "isStudent": false,

    "courses": ["Math", "Science", "Literature"],

    "address": {

        "street": "123 Main St",

        "city": "Wonderland"

    },

    "phoneNumbers": [

        {"type": "home", "number": "123-456-7890"},

        {"type": "work", "number": "987-654-3210"}

    ]

}

        详细解释:

        `"name": "Alice"`:键 `name` 的值是字符串 `"Alice"`。

        `"age": 30`:键 `age` 的值是数字 `30`。

        `"isStudent": false`:键 `isStudent` 的值是布尔值 `false`。

        `"courses": ["Math", "Science", "Literature"]`:键 `courses` 的值是一个数组,包含三个字符串。

        `"address": { "street": "123 Main St", "city": "Wonderland" }`:键 `address` 的值是一个对象,包含两个键值对。

        "phoneNumbers": [ { "type": "home", "number": "123-456-7890" }, { "type": "work", "number": "987-654-3210" } ]`:键 `phoneNumbers` 的值是一个数组,数组中包含两个对象,每个对象表示一个电话号码。

3.4 JSON 数据传输

        在客户端和服务器之间传输 JSON 数据的流程如下:

3.4.1 浏览器向服务器发送请求

        浏览器通过HTTP请求将JSON数据发送到服务器。

const data = {

    "name": "Alice",

    "age": 30

};



fetch('https://example.com/api', {

    method: 'POST',

    headers: {

        'Content-Type': 'application/json'

    },

    body: JSON.stringify(data)

})

.then(response => response.json())

.then(data => console.log(data))

.catch(error => console.error('Error:', error));

3.4.2 服务器处理请求

        服务器解析收到的JSON数据,并进行相应处理。

        示例(Node.js + Express):

const express = require('express');

const app = express();



app.use(express.json());



app.post('/api', (req, res) => {

    const receivedData = req.body;

    console.log(receivedData);

    res.json({ message: 'Data received', data: receivedData });

});



app.listen(3000, () => {

    console.log('Server is running on port 3000');

});

3.4.3 服务器响应

        服务器处理完请求后,将结果以JSON格式返回给客户端。

3.4.4 浏览器处理响应

        浏览器解析服务器返回的JSON数据,并进行展示或进一步操作。

fetch('https://example.com/api')

    .then(response => response.json())

    .then(data => console.log(data))

    .catch(error => console.error('Error:', error));

3.5 JSON 转换与解析

         将对象转换为 JSON 字符串

        使用 `JSON.stringify()` 方法。

const obj = {

    name: "Alice",

    age: 30

};

const jsonString = JSON.stringify(obj);

console.log(jsonString); // 输出: {"name":"Alice","age":30}

        将 JSON 字符串解析为对象

        使用 `JSON.parse()` 方法。

const jsonString = '{"name": "Alice", "age": 30}';

const obj = JSON.parse(jsonString);

console.log(obj.name); // 输出: Alice

console.log(obj.age);  // 输出: 30

3.6 常见应用场景

        配置文件

        JSON 常用作应用程序的配置文件格式,例如:

{

    "appName": "MyApp",

    "version": "1.0.0",

    "settings": {

        "theme": "dark",

        "notifications": true

    }

}

        数据存储

        JSON 可以用于存储结构化数据,例如:

[

    {

        "id": 1,

        "name": "Alice",

        "email": "alice@example.com"

    },

    {

        "id": 2,

        "name": "Bob",

        "email": "bob@example.com"

    }

]

        数据交换

        在 Web 应用中,JSON 常用于客户端与服务器之间的数据交换,例如 REST API 和 GraphQL。

3.7 JSON 与其他数据格式的比较

         JSON vs XML

        简洁性:JSON 更加简洁,减少了数据传输量。

        解析速度:JSON 解析速度更快,使用简单。

        易用性:JSON 更加直观,容易理解和使用。

        JSON vs CSV

        结构化数据:JSON 适合嵌套结构的数据,CSV 适合平面结构的数据。

        可读性:JSON 可读性强,CSV 更适合表格数据。

        灵活性:JSON 更灵活,支持复杂数据结构。

4. 总结

        JSON 是一种轻量级的数据交换格式,具有简洁、易读和易解析的特点,广泛应用于现代Web开发中。通过JSON,客户端和服务器之间可以高效地传输和处理数据,从而提升应用的性能和用户体验。

4.1 JSON 的优势

        简洁易用:相比XML,JSON更加简洁和直观。

        高效传输:较小的数据体积减少了传输时间。

        广泛支持:几乎所有的现代编程语言都支持JSON。

4.2 JSON 的局限性

        不支持注释:JSON 不支持在数据中添加注释,这在配置文件中可能是一个限制。

        数据类型限制:JSON 只支持基本数据类型,不支持日期、函数等复杂类型。

4.3 实际应用中的注意事项

        数据安全:在传输敏感数据时,需确保数据加密和传输安全。

        错误处理:在解析和生成JSON时,需做好错误处理,以避免数据格式错误导致的问题。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

解决obsidian加粗字体显示不突出的问题

加粗字体显示不突出的原因:默认字体的加粗版本本来就不突出 解决方法:改成显示突出的类型Microsoft YaHei UI 【效果】 修改前:修改后: 其他方法: 修改css(很麻烦,改半天也不一定奏效&#…

mac上使用finder时候,显示隐藏的文件或者文件夹

默认在finder中是不显示隐藏的文件和文件夹的,但是想创建.gitignore文件,并向里面写入内容,即便是打开xcode也是不显示这几个隐藏文件的,那有什么办法呢? 使用快捷键: 使用finder打开包含隐藏文件的文件夹…

CleanMyMac残留项可以删除吗 mac清理卸载残留文件怎么清理 如何清除MacBook上残留的软件垃圾

如果您不知道Mac电脑如何删除文件,不知道如何删除残留文件,不用担心,本篇文章为大家介绍删除普通文件和删除应用卸载后残留文件的方法。 苹果电脑怎么删除文件? 对于一般的文件,在Mac上将其删除掉不是一件很难的事&a…

【Python】字典练习

python期考练习 目录 1. 首都名​编辑 2. 摩斯电码 3. 登录 4. 学生的姓名和年龄​编辑 5. 电商 6. 学生基本信息 7. 字母数 1. 首都名 初始字典 (可复制) : d{"China":"Beijing","America":"Washington","Norway":…

信息学奥赛初赛天天练-42-CSP-J2020基础题-变量地址、编译器、逻辑运算、逻辑与运算、逻辑或运算、冒泡排序、递归应用

PDF文档公众号回复关键字:20240702 2020 CSP-J 选择题 单项选择题(共15题,每题2分,共计30分:每题有且仅有一个正确选项) 1.在内存储器中每个存储单元都被赋予一个唯一的序号,称为( &#xff0…

pandas数据分析(4)

修改DataFrame数据的最简单的方法是通过loc和iloc属性为某些元素赋值。 首先构造一组数据 通过标签或位置设置值 也可以一次修改多个值: 通过布尔索引设置数据 将所有来自China,或者年龄20以下的人名字设置为匿名: 通过替换值设置数据 如果…

粤港联动,北斗高质量国际化发展的重要机遇

今年是香港回归27周年,也是《粤港澳大湾区发展规划纲要》公布5周年,5年来各项政策、平台不断为粤港联动增添新动能。“十四五”时期的粤港澳大湾区,被国家赋予了更重大的使命,国家“十四五”《规划纲要》提出,以京津冀…

EEPROM内部原理

A2, A1, A0是EEPROM的地址引脚,用于设置设备地址。它们的作用如下: 设备寻址: 这三个引脚允许在I2C总线上唯一地标识EEPROM芯片。通过不同的连接方式(接高、接低或悬空),可以为同一类型的EEPROM芯片设置不同…

[PyTorch]:加速Pytorch 模型训练的几种方法(几行代码),最快提升八倍(附实验记录)

本篇文章转自:Some Techniques To Make Your PyTorch Models Train (Much) Faster 本篇博文概述了在不影响 PyTorch 模型准确性的情况下提高其训练性能的技术。为此,将 PyTorch 模型包装在 LightningModule 中,并使用 Trainer 类来实现各种训…

Ubuntu开通5005端口 记录

Ubuntu版本:20.04 使用systemctl status firewalld查看防火墙状态,报错Unit firewalld.service could not be found 报错的原因是没有安装firewall,安装命令为sudo apt install firewalld,然后进行安装 安装完成后输入systemctl…

【日常记录】【JS】动态执行JS脚本

文章目录 1、第一种方式:eval2、第二种方式:setTimeout3、第三种方式:创建script 标签插入body4、第四种方式:创建 Function5、对比6、 参考链接 1、第一种方式:eval 语法 eval(string)参数 string:一个…

Windows编程上

Windows编程[上] 一、Windows API1.控制台大小设置1.1 GetStdHandle1.2 SetConsoleWindowInfo1.3 SetConsoleScreenBufferSize1.4 SetConsoleTitle1.5 封装为Innks 2.控制台字体设置以及光标调整2.1 GetConsoleCursorInfo2.2 SetConsoleCursorPosition2.3 GetCurrentConsoleFon…

DLS-42/5-5双位置继电器 DC220V 板后接线 约瑟JOSEF

DLS-40系列双位置继电器型号: DLS-41/10-2双位置继电器; DLS-41/9-3双位置继电器 DLS-41/8-4双位置继电器; DLS-41/6-6双位置继电器; DLS-42/9-1双位置继电器; DLS-42/8-2双位置继电器; DLS-42/7-3双位…

2024护网整体工作预案示例

目录 第1章 HW整体工作工作部署 1.1 工作组织架构 1.2 各部门工作职责 1.3 演练期间工作机制 1.3.1 工作汇报机制 1.3.2 应急响应机制 第2章 系统资产梳理整改 2.1 敏感信息梳理整改 2.2 互联网资产发现 2.3 第三方供应商梳理 2.4 业务连接单位梳理 第3…

【C++】main函数及返回值深度解析

一.main函数介绍 1.main函数怎么写 #include <iostream>int main() {// 程序的代码放在这里std::cout << "Hello, World!" << std::endl;return 0; }在这个例子中&#xff1a; #include <iostream> 是预处理指令&#xff0c;它告诉编译器…

入门Axure:快速掌握原型设计技能

2002 年&#xff0c;维克托和马丁在旧金山湾区的一家初创公司工作&#xff0c;发现自己一再被软件开发生命周期的限制所困扰&#xff0c;而且产品团队在编写规范之前很难评估他们的解决方案&#xff0c;开发人员经常不理解&#xff08;或不阅读&#xff09;给出的规范&#xff…

02.C1W1.Sentiment Analysis with Logistic Regression

目录 Supervised ML and Sentiment AnalysisSupervised ML (training)Sentiment analysis Vocabulary and Feature ExtractionVocabularyFeature extractionSparse representations and some of their issues Negative and Positive FrequenciesFeature extraction with freque…

前端人注意了!Nuxt 的服务器专用组件应该引起你的关注!!

大家好&#xff0c;我是CodeQi&#xff01; 前几天&#xff0c;我和同事们在讨论 Nuxt.js 的一些新特性时&#xff0c;突然发现一件有趣的事情&#xff1a;Nuxt 的服务器专用组件&#xff08;Server-only Components&#xff09;引起了大家的极大兴趣。 为了不显得太落伍&am…

【unity实战】使用旧输入系统Input Manager 写一个 2D 平台游戏玩家控制器——包括移动、跳跃、滑墙、蹬墙跳

最终效果 文章目录 最终效果素材下载人物环境 简单绘制环境角色移动跳跃视差和摄像机跟随效果奔跑动画切换跳跃动画&#xff0c;跳跃次数限制角色添加2d物理材质&#xff0c;防止角色粘在墙上如果角色移动时背景出现黑线条方法一方法二 墙壁滑行实现角色滑墙不可以通过移动离开…

MySQL——事务ACID原则、脏读、不可重复读、幻读

什么是事务 要么都成功&#xff0c;要么都失败 一一一一一一一 1. SQL执行&#xff1a;A给B转账 A 1000 ---->200 B 200 2. SQL执行&#xff1a;B收到A的钱 A 800 B 400 一一一一一一一 将一组SQL放在一个批次中去执行~ 事务原则&#xff1a;ACI…