root / HServer / 00.Server / 00.Program / node_modules / lodash / clone.js
이력 | 보기 | 이력해설 | 다운로드 (1.04 KB)
| 1 |
var baseClone = require('./_baseClone'); |
|---|---|
| 2 |
|
| 3 |
/** Used to compose bitmasks for cloning. */
|
| 4 |
var CLONE_SYMBOLS_FLAG = 4; |
| 5 |
|
| 6 |
/**
|
| 7 |
* Creates a shallow clone of `value`.
|
| 8 |
*
|
| 9 |
* **Note:** This method is loosely based on the
|
| 10 |
* [structured clone algorithm](https://mdn.io/Structured_clone_algorithm)
|
| 11 |
* and supports cloning arrays, array buffers, booleans, date objects, maps,
|
| 12 |
* numbers, `Object` objects, regexes, sets, strings, symbols, and typed
|
| 13 |
* arrays. The own enumerable properties of `arguments` objects are cloned
|
| 14 |
* as plain objects. An empty object is returned for uncloneable values such
|
| 15 |
* as error objects, functions, DOM nodes, and WeakMaps.
|
| 16 |
*
|
| 17 |
* @static
|
| 18 |
* @memberOf _
|
| 19 |
* @since 0.1.0
|
| 20 |
* @category Lang
|
| 21 |
* @param {*} value The value to clone.
|
| 22 |
* @returns {*} Returns the cloned value.
|
| 23 |
* @see _.cloneDeep
|
| 24 |
* @example
|
| 25 |
*
|
| 26 |
* var objects = [{ 'a': 1 }, { 'b': 2 }];
|
| 27 |
*
|
| 28 |
* var shallow = _.clone(objects);
|
| 29 |
* console.log(shallow[0] === objects[0]);
|
| 30 |
* // => true
|
| 31 |
*/
|
| 32 |
function clone(value) { |
| 33 |
return baseClone(value, CLONE_SYMBOLS_FLAG);
|
| 34 |
} |
| 35 |
|
| 36 |
module.exports = clone; |