本文實(shí)例講述了JS 數(shù)組和對(duì)象的深拷貝操作。分享給大家供大家參考,具體如下:
一.數(shù)組的深拷貝
let arr = [ undefined, function(){ console.log(123); }, true, null, { name:"123", age:23 } ]; // arr作為拷貝對(duì)象
1. Array.from()
Array.from()能將一個(gè)類數(shù)組轉(zhuǎn)化成一個(gè)真正的數(shù)組,因此它返回的是一個(gè)新數(shù)組。
let arr1 = Array.from(arr); arr[0] = 2; console.log(arr1); // [ undefined, [Function], true, null, { name: '123', age: 23 } ]
2. Object.assign()
let arr1 = Object.assign([], arr) arr[0] = 2; console.log(arr1); // [ undefined, [Function], true, null, { name: '123', age: 23 } ]
此方法也可用作對(duì)象的深拷貝
3. Slice()
let arr1 = arr.slice(0); arr[0] = 2; console.log(arr1); // [ undefined, [Function], true, null, { name: '123', age: 23 } ]
4. Concat()
let arr1 = arr.concat(); arr[0] = 2; console.log(arr1); // [ undefined, [Function], true, null, { name: '123', age: 23 } ]
5. 擴(kuò)展運(yùn)算符深拷貝
// let [...arr1] = arr; // 這兩種都可以 let arr1 = [...arr]; arr[0] = 2; console.log(arr1); // [ undefined, [Function], true, null, { name: '123', age: 23 } ]
此方法也可用作對(duì)象的深拷貝
二.對(duì)象的深拷貝
let obj = { name: "a", age: 20, sex: false, user: { a: 20, n: "b" }, f: function(){ return 1; }, u: undefined, n: null }
用擴(kuò)展運(yùn)算符和Object.assign()方法可以深拷貝對(duì)象
let obj1 = Object.assign({}, obj) obj[age] = 2; console.log(obj1); // let obj = { name: "a", age: 20, sex: false,user: {a: 20,n: "b},f: function(){return 1;},u: undefined,n: null}
相關(guān)學(xué)習(xí)推薦:javascript視頻教程