Dynamic JSON modification tookit
Deep get and deep set properties on an object.
Get value at path
of object
. path
must be a string of the default Javascript syntax for retrieving
values in an object. If the value at path
does not exist, undefined
is returned.
object
- object to get values frompath
- path to values within object
var djson = require('djson');
var demo = {
foo: {
bar: [{
lorem: {
ipsum: 'dolor sit amet'
}
}]
}
};
djson.get(demo, 'foo.bar[0].lorem.ipsum'); // ==> 'dolor sit amet'
djson.get(demo, 'foo.bar[1].lorem'); // ==> undefined
Sets value at path
of object
. path
must be a string of the default Javascript syntax for retrieving
values in an object. If path
does not exist it's created.
object
- object to set values onpath
- path of property to setvalue
- value to set
var djson = require('djson');
var demo = {};
djson.set(demo, 'foo.bar.lorem.ipsum', 'dolor sit amet');
console.log(demo.foo.bar.lorem.ipsum); // ==> 'dolor sit amet'
There are some pitfalls to using this module:
Because the implementation uses a sandboxed eval
to retrieve properties on an object, requesting a property with
a dash directly will resolve in a dot notation of that property. The way to solve this is to use square bracket notation
of the retrieved property instead.
var djson = require('djson');
var demo = {
'with-dash': 'foo'
};
djson.get(demo, 'with-dash'); // is the same as demo.with-dash and will resolve to `undefined`
djson.get(demo, '["with-dash"]'); // ==> 'foo'
Dynamic creation of arrays is not supported at the moment.
var djson = require('djson');
var demo = {};
djson.set(demo, 'foo.bar[0].lorem', 'ipsum');
console.log(demo); // ==> { foo: { bar: { 0: { lorem: 'ipsum' } } } }
- Cleanup