溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JavaScript中淺拷貝和深拷貝的區別是什么

發布時間:2021-08-09 15:03:27 來源:億速云 閱讀:207 作者:Leah 欄目:web開發

本篇文章為大家展示了JavaScript中淺拷貝和深拷貝的區別是什么,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

前言

1. 基礎數據類型: undefined、boolean、number、string、null,保存在棧內存中的簡單數據

2. 引用數據類型:Array、對象、Function,保存在堆內存空間中

概述

如下圖:

JavaScript中淺拷貝和深拷貝的區別是什么

注釋:

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;

如下圖:

JavaScript中淺拷貝和深拷貝的區別是什么

引用數據類型的復制

var m ={ a:10, b:20};

var n = m;

JavaScript中淺拷貝和深拷貝的區別是什么

m與n指向同一個內存空間,當m或者n改變時,另一個也跟著改變

m.a = 'web秀';

console.log(n.a);

// 輸出 web秀

怎么樣使引用數據類型有各自獨立的內存空間???

深度拷貝方法

采用遞歸的方法拷貝對象

JavaScript中淺拷貝和深拷貝的區別是什么

## 奇技淫巧

利用**基礎數據類型**方式,把對象轉換成字符串,進行復制。具體點說就是,用JSON.stringify與JSON.parse實現深拷貝。原因是JSON.stringify(obj)轉換成字符串,變成基本數據類型,基本類型拷貝是直接在棧內存新開空間,直接復制一份名-值,不影響之前的對象。請看代碼:

JavaScript中淺拷貝和深拷貝的區別是什么

總結

1. 淺拷貝(shallow copy):只復制指向某個對象的指針,而不復制對象本身,新舊對象共享一塊內存;

2. 深拷貝(deep copy):復制并創建一個一摸一樣的對象,不共享內存,修改新對象,舊對象保持不變;

實現深拷貝主要有2種方法

(1)遞歸

(2)JSON.stringify結合JSON.parse

上述內容就是JavaScript中淺拷貝和深拷貝的區別是什么,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女