JS引用傳遞與值傳遞的區(qū)別與用法分析
本文實例講述了JS引用傳遞與值傳遞的區(qū)別與用法。分享給大家供大家參考,具體如下:
這里詳細(xì)解釋JS值傳遞和引用傳遞以及二者的區(qū)別。
我們先來解釋一下這兩個的基本概念吧。
函數(shù)調(diào)用中,傳遞是一個數(shù)值,我們稱為 “值傳遞”。
函數(shù)調(diào)用中,傳遞是對象,一般稱為 “引用傳遞”。
現(xiàn)在這里總體上說明,這二者的本質(zhì)區(qū)別就在于傳遞的數(shù)據(jù)類型不一樣,值傳遞傳遞的是一個值,而引用傳遞傳遞的是一個對象。
看一下代碼以及代碼中的注釋。
一、引入
function func(a) { a++; } // 因為函數(shù)都沒有調(diào)用,所以找不到 a console.log(a); //結(jié)果明顯是undefined了。 //所以看下面兩個例子。
二、值傳遞
var a = 5; function func(a) { // 函數(shù)中開辟了一個空間 a == 5 // a==6 a++; } func(5); // 結(jié)果,函數(shù)沒有改變到 外部 a 的值,所以,結(jié)果是 5 console.log(a); // 函數(shù)調(diào)用中,傳遞是一個數(shù)值,我們稱為 “值傳遞” // 特點: 有多個不同的空間,空間都是在棧中的 // 所以 修改函數(shù)中的空間,對外部空間是沒有影響的
三、引用傳遞
var a = 5; function func() { // 開辟函數(shù) 的空間 // 函數(shù)中沒有 a 的空間 // 所以,系統(tǒng)會自動向外面搜索 // 這里是對外部的變量進行修改 a++; } func(5); // 因為函數(shù)中修改了外部的變量 a,所以,值發(fā)生改變了,是 6 console.log(a); // 函數(shù)調(diào)用中,傳遞是對象,一般稱為 “引用傳遞” // 特點: 實在存數(shù)據(jù)的空間只有一份
詳細(xì)的說明我都在代碼中注釋說明了,歡迎指點指點指正。
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運算用法總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計有所幫助。
相關(guān)文章
JS/FLASH實現(xiàn)復(fù)制代碼到剪貼板(兼容所有瀏覽器)
使用javascript來寫復(fù)制到剪貼板的代碼,一般都是瀏覽器不兼容的。所以采用flash的方式,模擬一個層,再來復(fù)制,就可以做到全部瀏覽器都適用,具體實現(xiàn)如下,感興趣的朋友可以參考下哈2013-05-05鼠標(biāo)懸停小圖標(biāo)顯示大圖標(biāo)
這篇文章主要介紹了鼠標(biāo)懸停小圖標(biāo)顯示大圖標(biāo)的相關(guān)資料,需要的朋友可以參考下2016-01-01