成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

JavaScript中參數(shù)按值傳遞的示例分析

小編給大家分享一下JavaScript中參數(shù)按值傳遞的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

成都創(chuàng)新互聯(lián)堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站設(shè)計、成都做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的金鄉(xiāng)網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!

定義
ECMAScript中所有函數(shù)的參數(shù)都是按值傳遞的。

什么是按值傳遞呢?

也就是說,把函數(shù)外部的值復(fù)制給函數(shù)內(nèi)部的參數(shù),就和把值從一個變量復(fù)制到另一個變量一樣。

按值傳遞

舉個簡單的例子:

var value = 1;
function foo(v) {
  v = 2;
  console.log(v); //2
}
foo(value);
console.log(value) // 1

很好理解,當傳遞 value 到函數(shù) foo 中,相當于拷貝了一份 value,假設(shè)拷貝的這份叫 _value,函數(shù)中修改的都是 _value 的值,而不會影響原來的 value 值。

引用傳遞

拷貝雖然很好理解,但是當值是一個復(fù)雜的數(shù)據(jù)結(jié)構(gòu)的時候,拷貝就會產(chǎn)生性能上的問題。

所以還有另一種傳遞方式叫做按引用傳遞。

所謂按引用傳遞,就是傳遞對象的引用,函數(shù)內(nèi)部對參數(shù)的任何改變都會影響該對象的值,因為兩者引用的是同一個對象。

舉個例子:

var obj = {
  value: 1
};
function foo(o) {
  o.value = 2;
  console.log(o.value); //2
}
foo(obj);
console.log(obj.value) // 2

哎,不對啊,連我們的紅寶書都說了 ECMAScript 中所有函數(shù)的參數(shù)都是按值傳遞的,這怎么能按引用傳遞成功呢?

而這究竟是不是引用傳遞呢?

第三種傳遞方式

不急,讓我們再看個例子:

var obj = {
  value: 1
};
function foo(o) {
  o = 2;
  console.log(o); //2
}
foo(obj);
console.log(obj.value) // 1

如果 JavaScript 采用的是引用傳遞,外層的值也會被修改吶,這怎么又沒被改呢?所以真的不是引用傳遞嗎?

這就要講到其實還有第三種傳遞方式,叫按共享傳遞。

而共享傳遞是指,在傳遞對象的時候,傳遞對象的引用的副本。

注意:按引用傳遞是傳遞對象的引用,而按共享傳遞是傳遞對象的引用的副本!

所以修改 o.value,可以通過引用找到原值,但是直接修改 o,并不會修改原值。所以第二個和第三個例子其實都是按共享傳遞。

最后,你可以這樣理解:

參數(shù)如果是基本類型是按值傳遞,如果是引用類型按共享傳遞。

但是因為拷貝副本也是一種值的拷貝,所以在高程中也直接認為是按值傳遞了。

以上是“JavaScript中參數(shù)按值傳遞的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

新聞名稱:JavaScript中參數(shù)按值傳遞的示例分析
文章地址:http://jinyejixie.com/article0/gpgoio.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站營銷、網(wǎng)站收錄小程序開發(fā)、靜態(tài)網(wǎng)站、App設(shè)計、域名注冊

廣告

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

成都定制網(wǎng)站建設(shè)
孟州市| 阿克陶县| 贵州省| 汉阴县| 安乡县| 长子县| 西林县| 无极县| 温州市| 昌邑市| 新龙县| 武汉市| 乳山市| 九台市| 津南区| 湘西| 凤庆县| 云阳县| 兴国县| 河东区| 永仁县| 盘山县| 武山县| 尤溪县| 龙胜| 延吉市| 丰台区| 剑河县| 读书| 桂东县| 河北区| 南靖县| 忻城县| 沐川县| 富民县| 正宁县| 庄浪县| 安多县| 黔西| 达尔| 阿瓦提县|