1.0.14 • Published 7 years ago
node-digger v1.0.14
node-digger
Digs nested objects out using string or/and array notation
Installation:
Node:
npm install node-diggervar digger = require('node-digger');Browser:
Usage examples:
- Extract nested object
- Extract nested object using array input
- Using constructor to pass some of the inputs
- Using one-shot mode (less code)
- Providing default value
- Error handling
Extract nested object
var data = {a: {b: {c: {d: 10}}}};
console.log(new digger()
    .object(data)
    .level('a.b')
    .or(100)
    .dig());
// => { c: { d: 10 } }Extract nested object using array input
var data = {a: {b: {c: {d: 10}}}};
console.log(new digger()
    .object(data)
    .level(['a', 'b'])
    .or(100)
    .dig());
// => { c: { d: 10 } }Using constructor to pass some of the inputs
var data = {a: {b: {c: {d: 10}}}};
console.log(new digger(data, 'a.b')
    .or(100)
    .dig());
// => { c: { d: 10 } }Note: constructor parameter sequence is:
data, level, orValue, errorValueAll constructor parameters can also be specified using chained methods
Providing default value
var data = {a: {b: {c: {d: 10}}}};
console.log(new digger(data, 'a.b.c.d.e', 100)
    .dig());
// => 100   // default valueUsing one-shot mode (less code)
var data = {a: {b: {c: {d: 10}}}};
console.log(digger.dig(data, 'a.b.c.d', 100));
// => 10var data = {a: {b: {c: {d: 10}}}};
console.log(digger.dig(data, null, 100, "some error value"));
// => "some error value"Error handling
// provide default value on error
var data = {a: {b: {c: {d: 10}}}};
console.log(digger.dig(data, null, 100, "some error value"));
// => "some error value"// using method chaining
var data = {a: {b: {c: {d: 10}}}};
console.log(new digger()
    .object(data)
    .level(null)    // makes error condition true
    .or(100)
    .onError("some error value")
    .dig());
// => "some error value"// invoke callback on error
var data = {a: {b: {c: {d: 10}}}};
digger.dig(data, null, 100, function(err, data, level, defaultValue, errorValue){
    console.log(err, data, level, defaultValue, errorValue);
})
// => [Error statck trace], <data>, null, 100, [object Function]// using method chaining
var data = {a: {b: {c: {d: 10}}}};
new digger()
    .object(data)
    .level(null)
    .or(100)
    .onError(function(err, data, level, defaultValue, errorValue){
        console.log(err, data, level, defaultValue, errorValue);
    });
// => [Error statck trace], <data>, null, 100, [object Function]Note: Error value is used when either of
dataorlevelis null/undefinedException is thrown if error value is not specified and error condition is met
Using in browser
- Use service like rawgit with node-digger source file
- Use any of available CDN providers
- Use your own hosting
Then just include it in <script> tag of your page