在了解angular深拷貝之前,首先看下邊的代碼。
var a = 1;var b = a;b = 2;console.log(a + " " + b);
很顯然,輸出的a的值是1,b的值是2。接下來(lái)再看一段代碼。
var a = [1,2,3,4];var b = a;b.push(5);console.log(a + " " + b);
很顯然,輸出a的值是[1,2,3,4,5],b的值是[1,2,3,4,5]。再來(lái)看下一段代碼。
var a = { name:"zhangsan", age:20}var b = a;b.name = "lisi";b.age = 30;console.log(a + " " + b);很顯然,輸出的a和b的值都是{name:"lisi",age:30}。這是為什么呢?
在JavaScript或者其他語(yǔ)言中,都有深拷貝和淺拷貝這兩個(gè)名詞。在第一段代碼中,a和b都是基本數(shù)據(jù)類型,當(dāng)復(fù)制彼此的值之后,再改變值。此時(shí)a的值并沒(méi)有隨著b的值的改變而改變,這就是深拷貝。當(dāng)數(shù)據(jù)類型為數(shù)組或者對(duì)象這些復(fù)雜數(shù)據(jù)類型時(shí),復(fù)制到數(shù)組或者對(duì)象之后,再改變數(shù)組或者對(duì)象的值,a的值也隨著b的值改變而改變,這就是淺拷貝。
怎樣解決深拷貝這個(gè)問(wèn)題呢?
數(shù)組數(shù)據(jù)類型:使用concat()方法。b = a.concat();此時(shí)改變b的值,a的值就不會(huì)隨著b的值的改變而改變。
對(duì)象數(shù)據(jù)類型:b.name = a.name; b.age = a.age;此時(shí),改變b的值,a的值就不會(huì)隨著b的值的改變而改變。但是,該方法需要知道a對(duì)象里邊都有哪些字段。一個(gè)一個(gè)的復(fù)制,特別麻煩。
AngularJS的深拷貝
使用angular的同學(xué)可能都忽略了angularJS自帶的封裝好的方法。angular.isString(), angular.isNumber(),angular.isArray() , angular.isFunction() 等等。其中解決深拷貝的方法angular.copy(),能夠解決深拷貝的問(wèn)題。如下:
var a = { name :"zhangsan", age : 20}var b = angular.copy(a);此時(shí),改變b的值,a的值就不會(huì)隨著b的值的改變而改變,也就解決了深拷貝的問(wèn)題。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持錯(cuò)新站長(zhǎng)站。
|
新聞熱點(diǎn)
疑難解答
圖片精選