What are shallow cloning and deep cloning? Shallow cloning: directly assign the value stored in the stack to the corresponding variable. If it is a basic data type, the corresponding value is directly assigned. If it is a reference type, the address is assigned. 1. Clone the array1.1 Shallow cloningUse a for loop to do a shallow clone. var arr1 = ['demo', 1, 2]; var arr2 = []; // Shallow clone of array for (var i = 0; i < arr1.length; i++) { arr2[i] = arr1[i]; } console.log(arr2); console.log(arr1 == arr2); Output:
1.2 Deep cloningUse recursion for deep cloning. function deepClone(o) { var result = []; for (var i = 0; i < o.length; i++) { result.push(deepClone(o[i])); } return result; } 2. Cloning non-array objects2.1 Shallow CloningUse a for loop to do a shallow clone. var obj1 = { a: 1, b: 2, c: 3, d: [4, 5, { e: 'demo' }] }; var obj2 = {}; // Shallow clone of object for (var i in obj1) { obj2[i] = obj1[i]; } console.log(obj2); console.log(obj1 == obj2); Output:
2.2 Deep cloningUse recursion for deep cloning. function deepClone(o) { var result = {}; for (var i in o) { result[i] = deepClone(o[i]); } return result; } 3. Integrate deep clone functionvar obj1 = { a: 1, b: 2, c: 3, d: [4, 5, { e: 'demo' }] }; var arr1 = ['demo', 1, 2]; // Deep clone function deepClone(o) { if (Array.isArray(o)) { // is an array var result = []; for (var i = 0; i < o.length; i++) { result.push(deepClone(o[i])); } } else if (typeof o == 'object') { // Not an array, but an object var result = {}; for (var i in o) { result[i] = deepClone(o[i]); } } else { // Basic type value var result = o; } return result; } console.log(deepClone(arr1)); console.log(deepClone(obj1)); This concludes this article on the detailed principles of deep and shallow cloning of JavaScript arrays and non-array objects. For more relevant JavaScript array content, please search for previous articles on 123WORDPRESS.COM or continue to browse the related articles below. I hope everyone will support 123WORDPRESS.COM in the future! You may also be interested in:
|
<<: Detailed explanation of MySQL and Spring's autocommit
>>: Detailed tutorial on installing Tomcat8.5 in Centos8.2 cloud server environment
Table of contents Seconds_Behind_Master Original ...
<br />I have been working in front-end for s...
As the title says, otherwise when the page is revi...
Authorization is to grant certain permissions to ...
1. Overview of modules and instructions used to l...
Linux change hostname command 1. If you only need...
Document mode has the following two functions: 1. ...
For the beginner's first installation of MySQ...
Official website explanation: When a component is...
According to the methods of the masters, the caus...
Dockerfile is a file used to build a docker image...
Preface Today, when I was using a self-written co...
Table of contents Uncontrolled components Control...
Table of contents The node version does not corre...
After the docker installation is completed on the...