Skip to content

EmileSonneveld/serialize-to-js

 
 

Repository files navigation

serialize-to-js

NPM version Build Status

Serialize objects into a string while keeping circular structures and references. This string happens to be legitimate JavaScript and can be parsed back with eval().

Like JSON, but supporting Sets, Maps, Dates, circular references and more.

const codeStr = serialize(source, opts={})
eval(codeStr) // gives back the object!

serializes an object to JavaScript

Example

const serialize = require('serialize-to-js')
const reusedObject = { key: 'value' }
reusedObject.cyclicSelf = reusedObject
const obj = {
  s: 'hello world!',
  num: 3.1415,
  bool: true,
  nil: null,
  undef: undefined,
  obj: { foo: 'bar', reusedObject },
  arr: [1, '2', reusedObject],
  regexp: /^test?$/,
  date: new Date(),
  buffer: new Uint8Array([1, 2, 3]),
  set: new Set([1, 2, 3]),
  map: new Map([['a', 1], ['b', reusedObject]])
}
console.log(serialize(obj))

This gives the following string as result:

(function(){
  const root = {
    s: "hello world!",
    num: 3.1415,
    bool: true,
    nil: null,
    undef: undefined,
    obj: {
      foo: "bar",
      reusedObject: {
        key: "value",
        cyclicSelf: undefined /* Linked later*/
      }
    },
    arr: [
      1,
      "2",
      undefined /* Linked later*/
    ],
    regexp: new RegExp("^test?$", ""),
    date: new Date("2021-11-11T13:45:58.513Z"),
    buffer: new Uint8Array([1, 2, 3]),
    set: new Set([
      1,
      2,
      3
    ]),
    map: new Map([
      ["a", 1],
      ["b", undefined /* Linked later*/]
    ])
  };
  root.obj.reusedObject.cyclicSelf = root.obj.reusedObject;
  root.arr["2"] = root.obj.reusedObject;
  root.map.set("b", root.obj.reusedObject);
  return root;
})()

You can parse this results with eval(codeStr) to get back a real JS object.

Take a look to the tests for more examples.

Parameters

source: Object | Array | function | Any, source to serialize
opts: Object, options
opts.unsafe: Boolean, do not escape chars <>/
opts.ignoreFunction: Boolean, do not serialise functions, as they do not capture the scope correctly anyway. opts.objectsToLinkTo: Array, what objects can be linked to instead of serialised opts.maxDepth: Number, how deep may the object graph be searched Returns: String, serialized representation of source

Use cases

  • Dump the whole application state with serialise(window). You can Ctrl-F trough the generated code to find property names and values.
  • Make a dump before and after you pressed a button. You can diff the two dumps to see what changed.
  • Serialise your application state as a save file.
  • Check if your application has no unexpected duplicated objects. For example, when a bug lets an object be passed by reference instead of a copy. Those instances will clearly be visible at the end of the dump.

Contribution and License Agreement

If you contribute code to this project, you are implicitly allowing your code to be distributed under the MIT license. You are also implicitly verifying that all code is your original work or correctly attributed with the source of its origin and licence.

License

Copyright (c) 2016- commenthol (MIT License) Copyright (c) 2021- EmileSonneveld (MIT License)

See LICENSE for more info.

Build

npm install
path=%CD%/node_modules/.bin;%path%
:: Avoid ERR_OSSL_EVP_UNSUPPORTED:
SET NODE_OPTIONS=--openssl-legacy-provider
node_modules\.bin\webpack

About

serialize objects to javascript

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 96.8%
  • HTML 3.0%
  • Other 0.2%