forked from lodash/lodash
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathunset.js
33 lines (31 loc) · 795 Bytes
/
unset.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
import baseUnset from './.internal/baseUnset.js'
/**
* Removes the property at `path` of `object`.
*
* **Note:** This method mutates `object`.
*
* @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`.
* @see get, has, set
* @example
*
* const 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)
}
export default unset