You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					37 lines
				
				1.0 KiB
			
		
		
			
		
	
	
					37 lines
				
				1.0 KiB
			| 
								 
											3 years ago
										 
									 | 
							
								var baseClone = require('./_baseClone');
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/** Used to compose bitmasks for cloning. */
							 | 
						||
| 
								 | 
							
								var 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. An empty object is returned for uncloneable values such
							 | 
						||
| 
								 | 
							
								 * as error objects, functions, DOM nodes, and WeakMaps.
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * @static
							 | 
						||
| 
								 | 
							
								 * @memberOf _
							 | 
						||
| 
								 | 
							
								 * @since 0.1.0
							 | 
						||
| 
								 | 
							
								 * @category Lang
							 | 
						||
| 
								 | 
							
								 * @param {*} value The value to clone.
							 | 
						||
| 
								 | 
							
								 * @returns {*} Returns the cloned value.
							 | 
						||
| 
								 | 
							
								 * @see _.cloneDeep
							 | 
						||
| 
								 | 
							
								 * @example
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * var objects = [{ 'a': 1 }, { 'b': 2 }];
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * var shallow = _.clone(objects);
							 | 
						||
| 
								 | 
							
								 * console.log(shallow[0] === objects[0]);
							 | 
						||
| 
								 | 
							
								 * // => true
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								function clone(value) {
							 | 
						||
| 
								 | 
							
								  return baseClone(value, CLONE_SYMBOLS_FLAG);
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								module.exports = clone;
							 |