在瞭解angular深拷貝之前,首先看下邊的代碼。
var a = 1;
var b = a;
b = 2;
console.log(a + " " + b);
很顯然,輸出的a的值是1,b的值是2。接下來再看一段代碼。
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]。再來看下一段代碼。
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或者其他語言中,都有深拷貝和淺拷貝這兩個名詞。在第一段代碼中,a和b都是基本數據類型,當複製彼此的值之後,再改變值。此時a的值並沒有隨着b的值的改變而改變,這就是深拷貝。當數據類型爲數組或者對象這些複雜數據類型時,複製到數組或者對象之後,再改變數組或者對象的值,a的值也隨着b的值改變而改變,這就是淺拷貝。
怎樣解決深拷貝這個問題呢?
數組數據類型:使用concat()方法。b = a.concat();
此時改變b的值,a的值就不會隨着b的值的改變而改變。
對象數據類型:b.name = a.name; b.age = a.age;
此時,改變b的值,a的值就不會隨着b的值的改變而改變。但是,該方法需要知道a對象裏邊都有哪些字段。一個一個的複製,特別麻煩。
angularJS的深拷貝
使用angular的同學可能都忽略了angularJS自帶的封裝好的方法。angular.isString(), angular.isNumber(),angular.isArray() , angular.isFunction() 等等。其中解決深拷貝的方法angular.copy(),能夠解決深拷貝的問題。如下:
var a = {
name :"zhangsan",
age : 20
}
var b = angular.copy(a);
此時,改變b的值,a的值就不會隨着b的值的改變而改變,也就解決了深拷貝的問題。