首頁  >  文章  >  web前端  >  用於編寫設定檔和解析資料的 JSON 擴充

用於編寫設定檔和解析資料的 JSON 擴充

Susan Sarandon
Susan Sarandon原創
2024-11-07 00:29:021041瀏覽

JSON Extensions for writing config files and parsing data

JSON 是一種相當簡單的格式,這使得它易於使用、理解和解析。
但有時您需要的不僅僅是這些,讓我們看看一些常見的 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 也能夠解析的擴充!

NDJSON

換行符分隔的 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 用戶端中用於匯出和匯入文件。

JSONC / JSON5

對於下一個,有多種實現,每種都添加了自己的風格。讓我們看看 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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn