JSPM

canonical-json

0.0.3
  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 50720
  • Score
    100M100P100Q186182F
  • License BSD

a canonical json implementation

Package Exports

  • canonical-json
  • canonical-json/index2
  • canonical-json/index2.js

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (canonical-json) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

#Canonical JSON

The goal of this module is to implement a version of JSON.stringify that returns a canonical JSON format.

Canonical JSON means that the same object should always be stringified to the exact same string.
JavaScripts native JSON.stringify does not guarantee any order for object keys when serializing:

Properties of non-array objects are not guaranteed to be stringified in any particular order. Do not rely on ordering of properties within the same object within the stringification.

Source: https://developer.mozilla.org/en-US/docs/JavaScript/Reference/Global_Objects/JSON/stringify

This module implements two alternative solutions to this problem:

  • index.js is based on Douglas Crockford's json2.js. I modified it to serialize object keys sorted on the fly.
  • index2.js recursively creates a copy of the object to sort its keys. The copy is then simply passed to native JSON.stringify

It currently exports the index.js version.

##Performance comparison I compared the performance of native JSON.stringify and the two alternative implementations that output keys sorted:

native JSON.stringify: 75 ms
js JSON.stringify with sorted keys: 308 ms
copy and native JSON.stringify with sorted keys: 291 ms

The tests were run in Node.js on a 2011 MacBook Pro.
Performance test source: test/performance.js