/
unset.ts
37 lines (35 loc) · 924 Bytes
/
unset.ts
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
34
35
36
37
import baseUnset from "./.internal/baseUnset";
/**
* Removes the property at `path` of `object`.
*
* **Note:** This method mutates `object`.
*
* @since 5.3.0
* @category Object
* @param object The object to modify.
* @param path The path of the property to unset.
* @returns Returns `true` if the property is deleted, else `false`.
* @see [[get]],[[has]],[[set]]
* @example
*
* ```js
* 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': {} }] }
* ```
*/
export function unset<T>(object: T, path: Array<string>): T;
export function unset<T>(object: T, path: string): T;
export function unset(object: any, path: any): any {
return object == null ? true : baseUnset(object, path);
}
export default unset;