JSON 是一種相當簡單的格式,這使得它易於使用、理解和解析。
但有時您需要的不僅僅是這些,讓我們看看一些常見的 JSON 擴充。
擴充 JSON 正是它聽起來的樣子。這種 JSON 方言支援其他資料類型,例如日期,甚至允許您添加自己的類型。
下面的範例顯示了常規 JSON 和 EJSON 在序列化和重新解析包含日期的物件時的差異。
const EJSON = require('ejson') const event = { name: 'test', created_at: new Date() } const stingifiedJSON = JSON.stringify(event) const stingifiedEJSON = EJSON.stringify(event) // stringified console.log(stingifiedJSON) // {"name":"test","created_at":"2024-11-06T00:00:00Z"} console.log(stingifiedEJSON) // {"name":"test","created_at":{"$date":1730851200000}} // re-parsed console.log(typeof JSON.parse(stingifiedJSON).created_at) // string console.log(EJSON.parse(stingifiedEJSON).created_at instanceof Date) // true
這對於重新解析序列化資料非常有用,例如透過網路傳送資料時。
EJSON 是 MongoDB 在底層使用的內容(除了 BSON,JSON 的二進位格式)。
在本文列出的 JSON 擴充中,這是唯一一個常規 JSON 也能夠解析的擴充!
換行符分隔的 JSON 通常用於一次串流一個 JSON 物件。
它是這樣的:
{"name":"test","created_at":"2024-11-02T00:00:00Z"} {"name":"test 2","created_at":"2024-11-04T00:00:00Z"} {"name":"test 3","created_at":"2024-11-06T00:00:00Z"}
與常規 JSON 的不同之處在於,它沒有將資料包裝在數組中,並且每行後面都沒有逗號(因為它是換行符分隔的)。這使其成為串流媒體的完美候選者。
除了串流 JSON,我還看到這種格式(與 EJSON 一起)在 NoSQL 用戶端中用於匯出和匯入文件。
對於下一個,有多種實現,每種都添加了自己的風格。讓我們看看 JSON5,因為它是最完整的。
它們都試圖實現相同的目標:用於管理設定檔的人類可讀的、寬鬆的 JSON 格式。
JSON5 允許您新增註解、尾隨逗號、換行符、取消引號鍵等等。
{ // You can add comments!! unquoted: '< unquoted keys!', singleQuotes: 'I can use "double quotes" here', lineBreaks: "Supports line breaks!\ No \n's!", }
如您所見,JSON 擴充有各種形狀和大小。有些旨在供應用程式使用,其他則允許開發人員更輕鬆地建立設定檔。
下次您需要序列化/解析 JSON 時,看看這些擴充功能之一是否對您的用例有意義!
以上是用於編寫設定檔和解析資料的 JSON 擴充的詳細內容。更多資訊請關注PHP中文網其他相關文章!