0.1.0 • Published 10 years ago
put-value v0.1.0
put-value  
 
Update only existing values from an object, works with dot notation paths like
a.b.cand support deep nesting.
Features
- updates value of keyonly ifkeyexists
- updates only existing values of objwhen object is given tokey
- because set-valueupdate values if exist and add if not exist
- returns original object if keyis not an object or string
- returns empty object if objis not an object
- returns modified object otherwise
Install
npm i put-value --save
npm testUsage
For more use-cases see the tests
var put = require('put-value')
var obj = {
  a: {
    foo: 'bar'
  },
  b: {
    bb: 'bbb'
  }
}
put(123) //=> empty object {}
put(obj, {a: {bar: 'baz'}}) //=> original `obj`
put(obj, {a: 'foo'}})
//=> {
//   a: 'foo',
//   b: {
//     bb: 'bbb'
//   }
// }
put(obj, {zzz: 'xxx'}) //=> original `obj`
put(obj, 'foo', 'baz') //=> original `obj`
put(obj, 'foo.bar', 'baz') //=> original `obj`
put(obj, 'a', {foo: 123})
//=> {
//   a: {
//     foo: 123
//   },
//   b: {
//     bb: 'bbb'
//   }
// }
put(obj, 'a.foo', {baz: 'aaa'})
//=> {
//   a: {
//     foo: {
//       baz: 'aaa'
//     }
//   },
//   b: {
//     bb: 'bbb'
//   }
// }Contributing
Pull requests and stars are always welcome. For bugs and feature requests, please create an issue.
But before doing anything, please read the CONTRIBUTING.md guidelines.