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); // 輸出: Aliceconsole.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.pswp.cn/web/37401.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/37401.shtml
英文地址,請注明出處:http://en.pswp.cn/web/37401.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

JS對數據類型的檢測方式

1. typeof()對于基本數據類型沒問題,遇到引用數據類型就不管用 console.log( typeof 666 ); // number console.log( typeof [1,2,3] ); // object 2. instanceof()只能判斷引用數據類型,不能判斷基本數據類型 console.log( [] instanceof Array ) // tr…

Unity--協程--Coroutine

Unity–協程–Coroutine 1. 協程的基本概念 基本概念:不是線程,將代碼按照劃分的時間來執行,這個時間可以是具體的多少秒,也可以是物理幀的時間,也可以是一幀的繪制結束的時間。 協程的寫法:通過返回IEnumerator的函數實現,使用yield return語句暫停執…

Golang | Leetcode Golang題解之第205題同構字符串

題目: 題解: func isIsomorphic(s, t string) bool {s2t : map[byte]byte{}t2s : map[byte]byte{}for i : range s {x, y : s[i], t[i]if s2t[x] > 0 && s2t[x] ! y || t2s[y] > 0 && t2s[y] ! x {return false}s2t[x] yt2s[y] …

python 查找輪廓

在Python中,查找圖像的輪廓通常使用OpenCV庫。以下是一個簡單的示例代碼,展示了如何使用OpenCV來查找并繪制圖像的輪廓: pythonimport cv2 import numpy as np# 讀取圖像 image cv2.imread(your_image.jpg, 0) # 請將your_image.jpg替換為您…

設備樹下的 platform 驅動編寫

設備樹下的 platform 驅動編寫 設備樹下的 platform 驅動簡介 platform 驅動框架分為總線、設備和驅動,其中總線不需要我們這些驅動程序員去管理,這個是 Linux 內核提供的,我們在編寫驅動的時候只要關注于設備和驅動的具體實現即可。在沒有…

《昇思25天學習打卡營第6天 | 函數式自動微分》

《昇思25天學習打卡營第6天 | 函數式自動微分》 目錄 《昇思25天學習打卡營第6天 | 函數式自動微分》函數式自動微分簡單的單層線性變換模型函數與計算圖微分函數與梯度計算Stop Gradient 函數式自動微分 神經網絡的訓練主要使用反向傳播算法,模型預測值&#xff0…

建站小記:遷移域名DNS到CloudFlare

CloudFlare一直有賽博菩薩之稱,據說用它做DNS解析服務又快又好又免費,還能防DDOS攻擊,并且可以提供頁面訪問統計功能。 正好我博客網頁打開略卡頓,所以決定將自己的DNS解析遷移到CloudFlare。 1.登錄CF控制臺,添加自己…

LeetCode-刷題記錄-二分法合集(本篇blog會持續更新哦~)

一、二分查找概述 二分查找(Binary Search)是一種高效的查找算法,適用于有序數組或列表。(但其實只要滿足二段性,就可以使用二分法,本篇博客后面博主會持續更新一些題,來破除一下人們對“只有有…

(已解決)Adobe Flash Player已不再受支持

文章目錄 前言解決方案 前言 一般來說,很少遇到官方網站使用Adobe Flash Player來進行錄用名單公示了。但是,今天就偏偏遇到一次, 用谷歌瀏覽器打不開, 點了沒有反應,用其他的瀏覽器,例如windows自帶的那…

Golang | Leetcode Golang題解之第207題課程表

題目: 題解: func canFinish(numCourses int, prerequisites [][]int) bool {var (edges make([][]int, numCourses)indeg make([]int, numCourses)result []int)for _, info : range prerequisites {edges[info[1]] append(edges[info[1]], info[0]…

數據結構:期末考 第六次測試(總復習)

一、 單選題 (共50題,100分) 1、表長為n的順序存儲的線性表,當在任何位置上插入或刪除一個元素的概率相等時,插入一個元素所需移動元素的平均個數為( D ).(2.0) A、 &am…

在node環境使用MySQL

什么是Sequelize? Sequelize是一個基于Promise的NodeJS ORM模塊 什么是ORM? ORM(Object-Relational-Mapping)是對象關系映射 對象關系映射可以把JS中的類和對象,和數據庫中的表和數據進行關系映射。映射之后我們就可以直接通過類和對象來操作數據表和數據了, 就…

join()方法——連接字符串、元組、列表和字典

自學python如何成為大佬(目錄):https://blog.csdn.net/weixin_67859959/article/details/139049996?spm1001.2014.3001.5501 語法參考 join()方法用于連接字符串數組。將字符串、元組、列表中的元素以指定的字符(分隔符)連接生成一個新的字符串&#…

喜報 | 極限科技獲得北京市“創新型”中小企業資格認證

2024年6月20日,北京市經濟和信息化局正式發布《關于對2024年度4月份北京市創新型中小企業名單進行公告的通知》,極限數據(北京)科技有限公司憑借其出色的創新能力和卓越的企業實力,成功獲得“北京市創新型中小企業”的…

學會python——在excel中寫入數據(python實例十三)

目錄 1.認識Python 2.環境與工具 2.1 python環境 2.2 Visual Studio Code編譯 3 .想Excel中寫入數據 3.1 代碼構思 3.2 代碼實例 3.3 運行結果 4.總結 1.認識Python Python 是一個高層次的結合了解釋性、編譯性、互動性和面向對象的腳本語言。 Python 的設計具有很強的…

數據結構算法之B樹

一、緒論 1.1 數據結構的概念和作用 1.2 B樹的起源和應用領域 二、B樹的基本原理 2.1 B樹的定義和特點 2.2 B樹的結構和節點組成 2.3 B樹的插入 2.4 B樹的刪除操作 三、B樹的優勢和應用 3.1 B樹在數據庫系統中的應用 3.2 B樹在文件系統中的應用 3.3 B樹在內存管理中…

HTML5的多線程技術:Shared Worker的使用示例

Shared Worker 與普通的 Web Worker 類似,但不同之處在于它可以被多個瀏覽器窗口、標簽頁或者iframe共享,使得這些上下文之間能夠相互通信。下面是一個使用 Shared Worker 的完整示例。共享Worker腳本(sharedWorker.js) self.add…

isupper()方法——判斷字符串是否全由大寫字母組成

自學python如何成為大佬(目錄):https://blog.csdn.net/weixin_67859959/article/details/139049996?spm1001.2014.3001.5501 語法參考 isupper()方法用于判斷字符串中所有的字母是否都是大寫。isupper()方法的語法格式如下: str.isupper() 如果字符串中包含至少…

我是如何在bytemd中實現自定義目錄的

介紹 接著上文說完,實現了在markdown編輯器中插入視頻的能力,接下來還需要繼續優化 markdown文檔的閱讀體驗,比如 再加個目錄 熟悉markdown語法的朋友可能會說,直接在編輯時添加 toc 標簽,可以在文章頂部自動生成目錄…

實驗三 時序邏輯電路實驗

仿真 鏈接:https://pan.baidu.com/s/1z9KFQANyNF5PvUPPYFQ9Ow 提取碼:e3md 一、實驗目的 1、通過實驗,理解觸發的概念,理解JK、D等常見觸發器的功能; 2、通過實驗,加深集成計數器功能的理解,掌…