JS引用傳遞與值傳遞的區(qū)別與用法分析
本文實(shí)例講述了JS引用傳遞與值傳遞的區(qū)別與用法。分享給大家供大家參考,具體如下:
這里詳細(xì)解釋JS值傳遞和引用傳遞以及二者的區(qū)別。
我們先來(lái)解釋一下這兩個(gè)的基本概念吧。
函數(shù)調(diào)用中,傳遞是一個(gè)數(shù)值,我們稱(chēng)為 “值傳遞”。
函數(shù)調(diào)用中,傳遞是對(duì)象,一般稱(chēng)為 “引用傳遞”。
現(xiàn)在這里總體上說(shuō)明,這二者的本質(zhì)區(qū)別就在于傳遞的數(shù)據(jù)類(lèi)型不一樣,值傳遞傳遞的是一個(gè)值,而引用傳遞傳遞的是一個(gè)對(duì)象。
看一下代碼以及代碼中的注釋。
一、引入
function func(a) { a++; } // 因?yàn)楹瘮?shù)都沒(méi)有調(diào)用,所以找不到 a console.log(a); //結(jié)果明顯是undefined了。 //所以看下面兩個(gè)例子。
二、值傳遞
var a = 5; function func(a) { // 函數(shù)中開(kāi)辟了一個(gè)空間 a == 5 // a==6 a++; } func(5); // 結(jié)果,函數(shù)沒(méi)有改變到 外部 a 的值,所以,結(jié)果是 5 console.log(a); // 函數(shù)調(diào)用中,傳遞是一個(gè)數(shù)值,我們稱(chēng)為 “值傳遞” // 特點(diǎn): 有多個(gè)不同的空間,空間都是在棧中的 // 所以 修改函數(shù)中的空間,對(duì)外部空間是沒(méi)有影響的
三、引用傳遞
var a = 5; function func() { // 開(kāi)辟函數(shù) 的空間 // 函數(shù)中沒(méi)有 a 的空間 // 所以,系統(tǒng)會(huì)自動(dòng)向外面搜索 // 這里是對(duì)外部的變量進(jìn)行修改 a++; } func(5); // 因?yàn)楹瘮?shù)中修改了外部的變量 a,所以,值發(fā)生改變了,是 6 console.log(a); // 函數(shù)調(diào)用中,傳遞是對(duì)象,一般稱(chēng)為 “引用傳遞” // 特點(diǎn): 實(shí)在存數(shù)據(jù)的空間只有一份
詳細(xì)的說(shuō)明我都在代碼中注釋說(shuō)明了,歡迎指點(diǎn)指點(diǎn)指正。
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《javascript面向?qū)ο笕腴T(mén)教程》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
相關(guān)文章
jQuery實(shí)現(xiàn)動(dòng)態(tài)文字搜索功能
本文主要介紹了jQuery實(shí)現(xiàn)動(dòng)態(tài)文字搜索功能的分析過(guò)程,文章底部提供了完整的代碼。具有一定的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-01-01JS/FLASH實(shí)現(xiàn)復(fù)制代碼到剪貼板(兼容所有瀏覽器)
使用javascript來(lái)寫(xiě)復(fù)制到剪貼板的代碼,一般都是瀏覽器不兼容的。所以采用flash的方式,模擬一個(gè)層,再來(lái)復(fù)制,就可以做到全部瀏覽器都適用,具體實(shí)現(xiàn)如下,感興趣的朋友可以參考下哈2013-05-05es6 字符串String的擴(kuò)展(實(shí)例講解)
下面小編就為大家?guī)?lái)一篇es6 字符串String的擴(kuò)展(實(shí)例講解)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-08-08小程序server請(qǐng)求微信服務(wù)器超時(shí)的解決方法
這篇文章主要介紹了小程序server請(qǐng)求微信服務(wù)器超時(shí)的解決方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-05-05鼠標(biāo)懸停小圖標(biāo)顯示大圖標(biāo)
這篇文章主要介紹了鼠標(biāo)懸停小圖標(biāo)顯示大圖標(biāo)的相關(guān)資料,需要的朋友可以參考下2016-01-01js不能跳轉(zhuǎn)到上一頁(yè)面的問(wèn)題解決方法
用JS:history.go(-1)就可以回到A頁(yè)面,如果使用Click,Change事件等激發(fā)了頁(yè)面的回傳,此時(shí)用history.go(-1)就回不到A頁(yè)面了,遇到此問(wèn)題的朋友們可以祥看本文2013-03-03