Based on ekazakov's dumpjs
Sometimes you need serialize your objects to JSON and deserialize them back again. But JSON stringify/parse is not enough, because you need support circular links and restore custom object.
Dumpjs allow easily serialize to JSON and restore any object.
Main points:
- It handle circular links
- Preserve object identities
- Works with any level of nesting objects
- Support ES6 Map and Set
- Support custom serialization/deserialization handlers
It use ES6 collections internally and need polyfill in old browsers.
Target
Plain object or array which need to be serialized.
Options
options.serializer(key, value)
— custom serialization function
- If function returns
undefined
, then property will be ignored. Any other returned value will be serialized. If function returnsnull
, then property will be serialized asnull
(JSON.stringify
convertsundefined
tonull
). - Memorizes received value and invocation result. For the same value always return the same result.
Source
Valid JSON for deserialization
Options
options.deserializer(key, value)
– custom deserialization
- Memorizes received value and invocation result. For the same value always return the same result.
options.postDeserializer(item, visited, deserializer)
– custom post deserialization
- Define custom logic to further deserialize deserialized
item
. More items generated at this post deserialization phase should be pushed tovisited
Set for further processing, which will feed intopostDeserializer
again.deserializer
is the same process used in deserialization phase of givenitem
. When an explicitfalse
is returned, default post deserializers will be used
Circular links
var obj = {x: 1, y: {h: 'hello'}};
obj.y.o = obj;
JSON.stringify(obj);
// TypeError: Converting circular structure to JSON
var D = require('dumpjs');
D.dump(obj);
// {
// "@0": {
// "x": 1, "y": "@1"
// },
// "@1": {
// "h": "hello", "o": "@0"
// }
// }
Dumpjs creates IDs for every object and use them as references.
Preserve identities
var obj2 = {x: 1, y: 2};
var obj3 = [obj2, obj2];
var restored = JSON.parse(JSON.stringify(obj3));
restored[0] === restored[1]; // false
JSON.parse create completly different objects.
var restored = D.restore(D.dump(obj3));
restored[0] === restored[1]; // true
npm install --save dumpjs
Works in node and browser.