map-merge

1.1.0 • Public • Published

map-merge

deep merge two objects with a rule. A new object is always returned.

I fear this may be a haskelly thing, I suspect it might be an applicative functor.

almost the same module as deep-merge but not quite.

Example

var merge = require('map-merge')

merge(a, b, function (av, bv) {
  //use the value from b if a's corrisponding value is null/undefined
  return bv == null ? av : bv
  // btw, this is the default merge rule.
})

Objects {}

objects are merged by their keys, first all the keys in the left object are added, then any keys in the right object which are not in the left.

This determins the order the keys appear in.

var merge = require('map-merge')

var a = {
  a: 'apple',
  b: 'banana',
  d: 'durian'
}
var b = {
  b: 'banana',
  c: 'cherry'
  e: 'elderberry'
}

var c = merge(a, b)

the order of the keys in c will depend on the order in a and b

{
  a: 'apple',
  b: 'banana',
  d: 'durian',
  c: 'cherry',
  e: 'elderberry'
}

License

MIT

Dependencies (0)

    Dev Dependencies (1)

    Package Sidebar

    Install

    npm i map-merge

    Weekly Downloads

    85

    Version

    1.1.0

    License

    MIT

    Last publish

    Collaborators

    • nopersonsmodules