Security News
RubyGems.org Adds New Maintainer Role
RubyGems.org has added a new "maintainer" role that allows for publishing new versions of gems. This new permission type is aimed at improving security for gem owners and the service overall.
assign-deep
Advanced tools
Deeply assign the values of all enumerable-own-properties and symbols from one or more source objects to a target object. Returns the target object.
Deeply assign the values of all enumerable-own-properties and symbols from one or more source objects to a target object. Returns the target object.
Please consider following this project's author, Jon Schlinkert, and consider starring the project to show your :heart: and support.
Install with npm:
$ npm install --save assign-deep
Please update to version 1.0.1 or later, a critical bug was fixed in that version.
null
or undefined
source values.[[Get]]
is used on source objects and [[Set]]
is used on the target, so it will invoke getters and setters. Therefore it assigns properties versus just copying or defining new properties. Note that this should not be used for merging new properties into a prototype if the merge sources contain getters and you do not want [[Get]]
to be used on the getters. For copying property definitions and their enumerability into prototypes Object.getOwnPropertyDescriptor()
and Object.defineProperty()
should be used instead.const assign = require('assign-deep');
const config = {
admin: true,
author: {
name: { first: 'Joe' }
}
};
const locals = {
admin: false,
author: {
name: { last: 'Smith' },
username: 'joesmith'
}
};
console.log(assign(config, locals));
// {
// admin: false,
// author: {
// name: { first: 'Joe', last: 'Smith' },
// username: 'joesmith'
// }
// }
Pull requests and stars are always welcome. For bugs and feature requests, please create an issue.
Running and reviewing unit tests is a great way to get familiarized with a library and its API. You can install dependencies and run tests with the following command:
$ npm install && npm test
(This project's readme.md is generated by verb, please don't edit the readme directly. Any changes to the readme must be made in the .verb.md readme template.)
To generate the readme, run the following command:
$ npm install -g verbose/verb#dev verb-generate-readme && verb
You might also be interested in these projects:
Commits | Contributor |
---|---|
31 | jonschlinkert |
14 | doowb |
Jon Schlinkert
Copyright © 2019, Jon Schlinkert. Released under the MIT License.
This file was generated by verb-generate-readme, v0.8.0, on June 19, 2019.
FAQs
Deeply assign the values of all enumerable-own-properties and symbols from one or more source objects to a target object. Returns the target object.
We found that assign-deep demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 2 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
RubyGems.org has added a new "maintainer" role that allows for publishing new versions of gems. This new permission type is aimed at improving security for gem owners and the service overall.
Security News
Node.js will be enforcing stricter semver-major PR policies a month before major releases to enhance stability and ensure reliable release candidates.
Security News
Research
Socket's threat research team has detected five malicious npm packages targeting Roblox developers, deploying malware to steal credentials and personal data.