溫馨提示×

溫馨提示×

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

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

javascript中的值傳遞和引用傳遞的示例分析

發(fā)布時間:2021-01-21 14:16:31 來源:億速云 閱讀:205 作者:小新 欄目:web開發(fā)

這篇文章給大家分享的是有關(guān)javascript中的值傳遞和引用傳遞的示例分析的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

值傳遞是針對基本類型的,而引用傳遞是針對引用類型的。傳參可以理解為:復(fù)制變量的值,把這個副本傳遞給形參。

基本類型復(fù)制后,形參與實參完全是獨立的,不管改變哪一個,都不會對另一個產(chǎn)生影響。

引用傳遞本質(zhì)上還是傳值,具體的步驟是:1、先在棧中開辟形參引用。2、把實參引用的值傳遞給形參引用。

1、值傳遞

function add(num) {
    num++;
    console.log("形參:", num);
}

var a = 20;
add(a);
console.log("實參:", a);

結(jié)果如下:

javascript中的值傳遞和引用傳遞的示例分析

根據(jù)結(jié)果分析:調(diào)用add(a),傳遞的實參a=20,把實參復(fù)制一份,把復(fù)制本傳遞給形參num,所以num++后并沒有影響實參a的值。

2、引用傳遞

function setNum(obj) {
    obj.num = 10;
    console.log("形參:", obj);
}

var a = new Object();
setNum(a);
console.log("實參:", a);

結(jié)果如下:

javascript中的值傳遞和引用傳遞的示例分析

當(dāng)var a = new Object();時,下圖時變量和對象的關(guān)系:

javascript中的值傳遞和引用傳遞的示例分析

調(diào)用setNum(a);時,下圖是全局變量a和局部變量obj以及對象Object的關(guān)系:

javascript中的值傳遞和引用傳遞的示例分析

這段代碼創(chuàng)建了一個Object對象,變量(引用)a指向這個Object對象。調(diào)用setNum(a),在這個函數(shù)內(nèi)部,obj和a都引用的是同一Object對象,即a和obj都指向同一個堆內(nèi)存地址。所以,通過傳遞實參引用a,對形參引用obj添加num屬性后,也影響到了實參引用a。所以,很多人就會被這種假象所蒙蔽,錯誤的認(rèn)為:在局部作用域修改對象,會在全局對象中反映出來,就說明參數(shù)是引用傳遞。

所以,以下是我的進一步分析:

function setNum(obj) {
    obj.num = 10;
    obj = new Object();
    obj.num = 20;
    console.log("形參:", obj);
}

var a = new Object();
setNum(a);
console.log("實參:", a);

結(jié)果如下:

javascript中的值傳遞和引用傳遞的示例分析

在函數(shù)內(nèi)部創(chuàng)建obj對象 obj = new Object(); 下圖是a和obj以及Object的關(guān)系:

javascript中的值傳遞和引用傳遞的示例分析

這段代碼在前一個的基礎(chǔ)上,給setNum()函數(shù)中添加了兩行代碼:obj = new Object()改變了obj的指向;obj.num = 20給新創(chuàng)建的obj添加屬性。根據(jù)結(jié)果來看,形參的改變并沒有影響到實參,所以,在JS中,引用傳遞的本質(zhì)就是值傳遞。

感謝各位的閱讀!關(guān)于“javascript中的值傳遞和引用傳遞的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI