forked from lodash/lodash
-
Notifications
You must be signed in to change notification settings - Fork 0
/
clone.js
35 lines (32 loc) · 1.05 KB
/
clone.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
34
35
import baseClone from './.internal/baseClone.js'
/** Used to compose bitmasks for cloning. */
const CLONE_SYMBOLS_FLAG = 4
/**
* Creates a shallow clone of `value`.
*
* **Note:** This method is loosely based on the
* [structured clone algorithm](https://mdn.io/Structured_clone_algorithm)
* and supports cloning arrays, array buffers, booleans, date objects, maps,
* numbers, `Object` objects, regexes, sets, strings, symbols, and typed
* arrays. The own enumerable properties of `arguments` objects are cloned
* as plain objects. Object inheritance is preserved. An empty object is
* returned for uncloneable values such as error objects, functions, DOM nodes,
* and WeakMaps.
*
* @since 0.1.0
* @category Lang
* @param {*} value The value to clone.
* @returns {*} Returns the cloned value.
* @see cloneDeep
* @example
*
* const objects = [{ 'a': 1 }, { 'b': 2 }]
*
* const shallow = clone(objects)
* console.log(shallow[0] === objects[0])
* // => true
*/
function clone(value) {
return baseClone(value, CLONE_SYMBOLS_FLAG)
}
export default clone