中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

angularJS深拷貝是什么意思

發布時間:2021-08-17 10:36:05 來源:億速云 閱讀:145 作者:chen 欄目:web開發

本篇內容主要講解“angularJS深拷貝是什么意思”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“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的值的改變而改變,也就解決了深拷貝的問題。

到此,相信大家對“angularJS深拷貝是什么意思”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

台江县| 康平县| 昌都县| 建宁县| 尚志市| 淅川县| 长顺县| 眉山市| 电白县| 理塘县| 越西县| 罗山县| 廊坊市| 买车| 峨眉山市| 洛阳市| 女性| 思茅市| 江山市| 南皮县| 弋阳县| 庄浪县| 武宁县| 浦县| 南昌县| 晴隆县| 沈阳市| 象山县| 梅州市| 凌云县| 壤塘县| 九龙城区| 长乐市| 西峡县| 丰县| 海盐县| 迁西县| 清水河县| 竹北市| 广南县| 大新县|