国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

angularJS深拷貝詳解

2019-11-19 17:04:12
字體:
來源:轉載
供稿:網友

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 深圳市| 淮阳县| 固阳县| 汕头市| 新建县| 宝清县| 西昌市| 屯门区| 施甸县| 府谷县| 宜川县| 北京市| 府谷县| 隆昌县| 炉霍县| 贵港市| 枣庄市| 石河子市| 昌都县| 贺州市| 勐海县| 虹口区| 新宁县| 舟曲县| 沧州市| 梧州市| 太康县| 微山县| 斗六市| 五峰| 惠水县| 耿马| 格尔木市| 西乌| 逊克县| 甘孜县| 开阳县| 米林县| 防城港市| 高青县| 页游|