142 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Markdown
		
	
	
		
		
			
		
	
	
			142 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Markdown
		
	
	
| 
								 | 
							
								deepmerge
							 | 
						||
| 
								 | 
							
								=========
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								> ~540B gzipped, ~1.1kB minified
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Merge the enumerable attributes of two objects deeply.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								the future
							 | 
						||
| 
								 | 
							
								----------
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Should we publish a version 2?  [Give your opinion.](https://github.com/KyleAMathews/deepmerge/issues/72)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								example
							 | 
						||
| 
								 | 
							
								=======
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								<!--js
							 | 
						||
| 
								 | 
							
								var merge = require('./')
							 | 
						||
| 
								 | 
							
								-->
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								var x = {
							 | 
						||
| 
								 | 
							
								    foo: { bar: 3 },
							 | 
						||
| 
								 | 
							
								    array: [{
							 | 
						||
| 
								 | 
							
								        does: 'work',
							 | 
						||
| 
								 | 
							
								        too: [ 1, 2, 3 ]
							 | 
						||
| 
								 | 
							
								    }]
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								var y = {
							 | 
						||
| 
								 | 
							
								    foo: { baz: 4 },
							 | 
						||
| 
								 | 
							
								    quux: 5,
							 | 
						||
| 
								 | 
							
								    array: [{
							 | 
						||
| 
								 | 
							
								        does: 'work',
							 | 
						||
| 
								 | 
							
								        too: [ 4, 5, 6 ]
							 | 
						||
| 
								 | 
							
								    }, {
							 | 
						||
| 
								 | 
							
								        really: 'yes'
							 | 
						||
| 
								 | 
							
								    }]
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								var expected = {
							 | 
						||
| 
								 | 
							
								    foo: {
							 | 
						||
| 
								 | 
							
								        bar: 3,
							 | 
						||
| 
								 | 
							
								        baz: 4
							 | 
						||
| 
								 | 
							
								    },
							 | 
						||
| 
								 | 
							
								    array: [{
							 | 
						||
| 
								 | 
							
								        does: 'work',
							 | 
						||
| 
								 | 
							
								        too: [ 1, 2, 3, 4, 5, 6 ]
							 | 
						||
| 
								 | 
							
								    }, {
							 | 
						||
| 
								 | 
							
								        really: 'yes'
							 | 
						||
| 
								 | 
							
								    }],
							 | 
						||
| 
								 | 
							
								    quux: 5
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								merge(x, y) // => expected
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								methods
							 | 
						||
| 
								 | 
							
								=======
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								var merge = require('deepmerge')
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								merge(x, y, [options])
							 | 
						||
| 
								 | 
							
								-----------
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Merge two objects `x` and `y` deeply, returning a new merged object with the
							 | 
						||
| 
								 | 
							
								elements from both `x` and `y`.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								If an element at the same key is present for both `x` and `y`, the value from
							 | 
						||
| 
								 | 
							
								`y` will appear in the result.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Merging creates a new object, so that neither `x` or `y` are be modified.  However, child objects on `x` or `y` are copied over - if you want to copy all values, you must pass `true` to the clone option.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								merge.all(arrayOfObjects, [options])
							 | 
						||
| 
								 | 
							
								-----------
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Merges two or more objects into a single result object.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								var x = { foo: { bar: 3 } }
							 | 
						||
| 
								 | 
							
								var y = { foo: { baz: 4 } }
							 | 
						||
| 
								 | 
							
								var z = { bar: 'yay!' }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								var expected = { foo: { bar: 3, baz: 4 }, bar: 'yay!' }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								merge.all([x, y, z]) // => expected
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								### options
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### arrayMerge
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								The merge will also merge arrays and array values by default.  However, there are nigh-infinite valid ways to merge arrays, and you may want to supply your own.  You can do this by passing an `arrayMerge` function as an option.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								function concatMerge(destinationArray, sourceArray, options) {
							 | 
						||
| 
								 | 
							
									destinationArray // => [1, 2, 3]
							 | 
						||
| 
								 | 
							
									sourceArray // => [3, 2, 1]
							 | 
						||
| 
								 | 
							
									options // => { arrayMerge: concatMerge }
							 | 
						||
| 
								 | 
							
									return destinationArray.concat(sourceArray)
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								merge([1, 2, 3], [3, 2, 1], { arrayMerge: concatMerge }) // => [1, 2, 3, 3, 2, 1]
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								To prevent arrays from being merged:
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								const dontMerge = (destination, source) => source
							 | 
						||
| 
								 | 
							
								const output = merge({ coolThing: [1,2,3] }, { coolThing: ['a', 'b', 'c'] }, { arrayMerge: dontMerge })
							 | 
						||
| 
								 | 
							
								output // => { coolThing: ['a', 'b', 'c'] }
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### clone
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Defaults to `false`.  If `clone` is `true` then both `x` and `y` are recursively cloned as part of the merge.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								install
							 | 
						||
| 
								 | 
							
								=======
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								With [npm](http://npmjs.org) do:
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```sh
							 | 
						||
| 
								 | 
							
								npm install deepmerge
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Just want to download the file without using any package managers/bundlers?  [Download the UMD version from unpkg.com](https://unpkg.com/deepmerge/dist/umd.js).
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								test
							 | 
						||
| 
								 | 
							
								====
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								With [npm](http://npmjs.org) do:
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```sh
							 | 
						||
| 
								 | 
							
								npm test
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								license
							 | 
						||
| 
								 | 
							
								=======
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								MIT
							 |