實現JS數據拷貝 實現一個函數 clone ,可以對JavaScript 中的 5種主要的數據類型(包括Number、String、Object、Array、Boolean)進行值復制。 function clone(obj) { var o; switch(typeof ...
JS的拷貝可分為淺拷貝和深拷貝: 淺拷貝:如果數組元素是基本類型,就會拷貝一份,互不影響,而如果是對象或者數組,就會只拷貝對象和數組的引用,這樣我們無論在新舊數組進行了修改,兩者都會發生變化。 深拷貝:就是指完全的拷貝一個對象,即使嵌套了對象,兩者也相互分離,修改一個對象的屬性,也不會影響另一個。 通常我們用的slice 截取 concat 拼接 函數,都是淺拷貝。 如果需要深拷貝,有如下 種方法 ...
2019-10-16 09:15 0 1103 推薦指數:
實現JS數據拷貝 實現一個函數 clone ,可以對JavaScript 中的 5種主要的數據類型(包括Number、String、Object、Array、Boolean)進行值復制。 function clone(obj) { var o; switch(typeof ...
var a1 = [1,2,3]; var a2 = a1; a2[0] = 90; console.log(a1[0]) //90 解析:數組是復合的數據類型,直接復制的話,只是復制了指向底層數據結構的指針,而不能克隆一個全新的數據; 上面的代碼中,a2並不是a1的克隆,而是指向同一分數據 ...
一、數組的深淺拷貝 在使用JavaScript對數組進行操作的時候,我們經常需要將數組進行備份,事實證明如果只是簡單的將它賦予其他變量,那么我們只要更改其中的任何一個,然后其他的也會跟着改變,這就導致了問題的發生。 像上面的這種直接賦值的方式就是淺拷貝,很多時候,這樣並不是 ...
一、預備知識 1.1、JS數據類型 基本數據類型:Boolean、String、Number、null、undefined 引用數據類型:Object、Array、Function、RegExp、Date等 1.2、數據類型的復制 基本數據類型的復制,是按值傳遞 ...
淺度拷貝:復制一層對象的屬性,並不包括對象里面的為引用類型的數據,當改變拷貝的對象里面的引用類型時,源對象也會改變。· 深度拷貝:重新開辟一個內存空間,需要遞歸拷貝對象里的引用,直到子屬性都為基本類型。兩個對象對應兩個不同的地址,修改一個對象的屬性,不會改變另一個對象的屬性 ...
js淺拷貝和深拷貝 一、總結 一句話總結: 1、Array的slice和concat方法:Array、Object等引用類型還是淺拷貝 2、JSON對象的parse和stringify:只能處理四種基本類型:Number、String、Boolean、Null ...
最近在開發中遇到一個小問題,就是由於js的淺拷貝導致變量被污染,突然發現對於js的變量值傳遞和引用傳值並沒有特別注意,如今總結如下,以備來者考慮。 JS的變量分普通類型和引用類型,具體如下: 基本數據類型:String,Boolean,Number,Undefined,Null; 引用 ...
寫在前面: 在了解深淺拷貝之前,我們先來了解一下堆棧。 堆棧是一種數據結構,在JS中 棧:由編譯器自動分配釋放 ,存放函數的參數值,局部變量的值等。 讀寫快,但是存儲的內容較少 堆:一般由程序員分配釋放, 若程序員不釋放,程序結束時可能由OS回收 ...