angularJS深拷貝

在瞭解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的值的改變而改變,也就解決了深拷貝的問題。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章