JavaScript中淺拷貝和深拷貝的區別和實現
前言
要理解 JavaScript中淺拷貝和深拷貝的區別,首先要明白JavaScript的資料型別。JavaScript有兩種資料型別,基礎資料型別和引用資料型別。
1. 基礎資料型別: undefined、boolean、number、string、null,儲存在棧記憶體中的簡單資料
2. 引用資料型別:Array、物件、Function,儲存在堆記憶體空間中
概述
如下圖:

註釋:
a1 = 0;a2 = 'this is str';a3 = null, 存放在棧記憶體中;
var c =[1,2,3] 與 var d = {m:20} ,**變數名與記憶體地址儲存在棧記憶體中**,**但是**[1,2,3]與{m:20} 作為**物件儲存在堆記憶體中**;
基礎資料型別的複製
var a = 20;
var b = a;
如下圖:

引用資料型別的複製
var m ={ a:10, b:20};
var n = m;

m與n指向同一個記憶體空間,當m或者n改變時,另一個也跟著改變
如
m.a = 'web秀';
console.log(n.a);
// 輸出 web秀
怎麼樣使引用資料型別有各自獨立的記憶體空間???
深度拷貝方法
採用遞迴的方法拷貝物件

## 奇技淫巧
利用**基礎資料型別**方式,把物件轉換成字串,進行復制。具體點說就是,用JSON.stringify與JSON.parse實現深拷貝。原因是JSON.stringify(obj)轉換成字串,變成基本資料型別,基本型別拷貝是直接在棧記憶體新開空間,直接複製一份名-值,不影響之前的物件。請看程式碼:

總結
1. 淺拷貝(shallow copy):只複製指向某個物件的指標,而不復制物件本身,新舊物件共享一塊記憶體;
2. 深拷貝(deep copy):複製並建立一個一摸一樣的物件,不共享記憶體,修改新物件,舊物件保持不變;
實現深拷貝主要有2種方法
(1)遞迴
(2)JSON.stringify結合JSON.parse
【責任編輯:龐桂玉 TEL:(010)68476606】