Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/alexbinary/object-deep-assign
Like Object.assign() but deep 😱
https://github.com/alexbinary/object-deep-assign
Last synced: about 1 month ago
JSON representation
Like Object.assign() but deep 😱
- Host: GitHub
- URL: https://github.com/alexbinary/object-deep-assign
- Owner: alexbinary
- License: mit
- Created: 2016-12-03T10:28:53.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2017-01-28T08:51:08.000Z (about 8 years ago)
- Last Synced: 2025-01-07T05:08:31.807Z (about 2 months ago)
- Language: JavaScript
- Homepage:
- Size: 32.2 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# object-deep-assign
Like `Object.assign()` but deep 😱
[data:image/s3,"s3://crabby-images/df637/df6378d86d7760cf7c71978d1df5068cdd1ce8f6" alt="npm"](https://www.npmjs.com/package/@alexbinary/object-deep-assign)
[data:image/s3,"s3://crabby-images/a82dc/a82dc33e20b14051636903ff6a5fe893d79cdcc1" alt="GitHub release"](https://github.com/alexbinary/object-deep-assign/releases/latest)
[data:image/s3,"s3://crabby-images/fe881/fe88183c42c6b9058983744b2ba2b0cb05994de1" alt="Build Status"](https://travis-ci.org/alexbinary/object-deep-assign)
[data:image/s3,"s3://crabby-images/78eab/78eab8c3b2cf2c1b820adbb21cfdaf4b56fcd106" alt="dependencies Status"](https://david-dm.org/alexbinary/object-deep-assign)
[data:image/s3,"s3://crabby-images/8ceef/8ceef217dbd1aae660b7bef7de410acd0e47beb8" alt="devDependencies Status"](https://david-dm.org/alexbinary/object-deep-assign?type=dev)Ever needed to do `Object.assign()` but couldn't because you had nested objects that got overwritten instead of merged ?
`object-deep-assign` merges objects recursively and can work with any depth. It has an API similar to `Object.assign()`.
`object-deep-assign` comes handy when you need to deal with e.g. configuration objects when you have a layered config system (e.g. a default, global and local config).
## Example
```javascript
let objectDeepAssign = require('@alexbinary/object-deep-assign')let defaultConf = {
build: true,
notify: {
on_success: false,
on_failure: true,
options: {
admin_only: true
retry: 1
}
}
}let globalConf = {
notify: {
on_success: true
options: {
retry: 2
}
}
}let userConf = {
notify: {
options:
admin_only: false
retry: 3
},
deploy: true
}let finalConf = objectDeepAssign({}, defaultConf, globalConf, userConf)
// finalConf = {
// build: true,
// deploy: true,
// notify: {
// on_success: true,
// on_failure: true,
// options: {
// admin_only: false,
// retry: 3
// }
// }
// }
```## Motivation
I wanted to try and write this thing myself, with the simplest code possible.
## Compatibility
The code is written in plain ES2015, so it does not run on node before version 6.
## Install
Install with [npm](https://www.npmjs.com) or [yarn](https://yarnpkg.com) :
```bash
$ npm install @alexbinary/object-deep-assign
# or
$ yarn add @alexbinary/object-deep-assign
```## Documentation
```javascript
let objectDeepAssign = require('@alexbinary/object-deep-assign')
```### objectDeepAssign(target, ...sources)
Copies properties of `sources` onto `target`.
Scalar properties with same name are replaced. Object properties are merged recursively. Sources are merged sequentially into target from left to right.
Returns `target`.
## Tests
Tests are written with [mocha](http://mochajs.org) and [chai](http://chaijs.com). To run the tests first do :
```bash
$ npm install # or `yarn`
```
to install the dev dependencies, and then do :
```bash
$ npm test # or `yarn test`
```To run the test in watch mode do :
```bash
$ npm testw # or `yarn testw`
```## Contributions
Contributions are welcome, feel free to [open issues](https://github.com/alexbinary/object-deep-assign/issues) and [submit pull requests](https://github.com/alexbinary/object-deep-assign/pulls) on [GitHub](https://github.com/alexbinary/object-deep-assign) !
## Related
- [object-assign-deep](https://www.npmjs.com/package/object-assign-deep) by [saikojosh](https://npmjs.com/~saikojosh)
- [object-extender](https://www.npmjs.com/package/object-extender) by [saikojosh](https://npmjs.com/~saikojosh)
- [deep-assign](https://www.npmjs.com/package/deep-assign) by [sindresorhus](https://npmjs.com/~sindresorhus)
- [assign-deep](https://www.npmjs.com/package/assign-deep) by [jonschlinkert](https://npmjs.com/~jonschlinkert)
- [merge-deep](https://www.npmjs.com/package/merge-deep) by [jonschlinkert](https://npmjs.com/~jonschlinkert)
- [mixin-deep](https://www.npmjs.com/package/mixin-deep) by [jonschlinkert](https://npmjs.com/~jonschlinkert)
- [mini-deep-assign](https://www.npmjs.com/package/mini-deep-assign) by [alykoshin](https://npmjs.com/~alykoshin)
- [object-merge](https://www.npmjs.com/package/object-merge) by [kastor](https://npmjs.com/~kastor)## Licence
MIT