angularJS深拷貝是什么意思-創(chuàng)新互聯(lián)

本篇內(nèi)容主要講解“angularJS深拷貝是什么意思”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“angularJS深拷貝是什么意思”吧!

成都創(chuàng)新互聯(lián)公司長期為近1000家客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對(duì)不同對(duì)象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺(tái),與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為臨翔企業(yè)提供專業(yè)的成都做網(wǎng)站、網(wǎng)站制作,臨翔網(wǎng)站改版等技術(shù)服務(wù)。擁有10年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。

在了解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或者其他語言中,都有深拷貝和淺拷貝這兩個(gè)名詞。在第一段代碼中,a和b都是基本數(shù)據(jù)類型,當(dāng)復(fù)制彼此的值之后,再改變值。此時(shí)a的值并沒有隨著b的值的改變而改變,這就是深拷貝。當(dāng)數(shù)據(jù)類型為數(shù)組或者對(duì)象這些復(fù)雜數(shù)據(jù)類型時(shí),復(fù)制到數(shù)組或者對(duì)象之后,再改變數(shù)組或者對(duì)象的值,a的值也隨著b的值改變而改變,這就是淺拷貝。

怎樣解決深拷貝這個(gè)問題呢?

數(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(),能夠解決深拷貝的問題。如下:

var a = {
  name :"zhangsan",
  age : 20
}
var b = angular.copy(a);

此時(shí),改變b的值,a的值就不會(huì)隨著b的值的改變而改變,也就解決了深拷貝的問題。

到此,相信大家對(duì)“angularJS深拷貝是什么意思”有了更深的了解,不妨來實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)建站網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站muchs.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

當(dāng)前名稱:angularJS深拷貝是什么意思-創(chuàng)新互聯(lián)
瀏覽路徑:http://muchs.cn/article28/dcoejp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供用戶體驗(yàn)、小程序開發(fā)、動(dòng)態(tài)網(wǎng)站全網(wǎng)營銷推廣、自適應(yīng)網(wǎng)站、移動(dòng)網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

營銷型網(wǎng)站建設(shè)