You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
35 lines
804 B
JavaScript
35 lines
804 B
JavaScript
6 years ago
|
var baseUnset = require('./_baseUnset');
|
||
|
|
||
|
/**
|
||
|
* Removes the property at `path` of `object`.
|
||
|
*
|
||
|
* **Note:** This method mutates `object`.
|
||
|
*
|
||
|
* @static
|
||
|
* @memberOf _
|
||
|
* @since 4.0.0
|
||
|
* @category Object
|
||
|
* @param {Object} object The object to modify.
|
||
|
* @param {Array|string} path The path of the property to unset.
|
||
|
* @returns {boolean} Returns `true` if the property is deleted, else `false`.
|
||
|
* @example
|
||
|
*
|
||
|
* var object = { 'a': [{ 'b': { 'c': 7 } }] };
|
||
|
* _.unset(object, 'a[0].b.c');
|
||
|
* // => true
|
||
|
*
|
||
|
* console.log(object);
|
||
|
* // => { 'a': [{ 'b': {} }] };
|
||
|
*
|
||
|
* _.unset(object, ['a', '0', 'b', 'c']);
|
||
|
* // => true
|
||
|
*
|
||
|
* console.log(object);
|
||
|
* // => { 'a': [{ 'b': {} }] };
|
||
|
*/
|
||
|
function unset(object, path) {
|
||
|
return object == null ? true : baseUnset(object, path);
|
||
|
}
|
||
|
|
||
|
module.exports = unset;
|