溫馨提示×

溫馨提示×

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

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

JavaScript按值傳遞

發(fā)布時(shí)間:2020-05-14 15:46:59 來源:億速云 閱讀:170 作者:Leah 欄目:web開發(fā)

這篇文章主要為大家詳細(xì)介紹了JavaScript按值傳遞的方法,文中示例代碼介紹的非常詳細(xì),零基礎(chǔ)也能參考此文章,感興趣的小伙伴們可以參考一下。

概述

參數(shù)的傳遞分為按值傳遞和按引用傳遞,而 JavaScript 中參數(shù)的傳遞只有按值傳遞。

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

所謂按值傳遞就是:

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

我們知道 JS 中,既有基本數(shù)據(jù)類型又有引用數(shù)據(jù)類型,那么二者的按值傳遞有什么樣的區(qū)別呢?

先給結(jié)論

在向參數(shù)傳遞基本數(shù)據(jù)類型時(shí),被傳遞的值會(huì)被復(fù)制給一個(gè)局部變量(arguments 類數(shù)組對象中的一個(gè)元素)。在向參數(shù)傳遞引用數(shù)據(jù)類型時(shí),會(huì)把這個(gè)值的內(nèi)存地址賦給一個(gè)局部變量。

一、數(shù)據(jù)類型

在 JS 中,數(shù)據(jù)類型分為基本類型和引用類型。

其中基本類型包括:number, string, boolean, undefined, null, Symbol(es 6 新增)。基本類型的值是保存在棧內(nèi)存當(dāng)中的。

基本數(shù)據(jù)類型的值本身是不會(huì)改變的。

let num1 = 5;
let num2 = num1;

JavaScript按值傳遞

將保存著原始值的變量 num1 賦值給 num2 后,會(huì)將原始值 num1 的副本賦值給新變量 num2, 此后這兩個(gè)變量是完全獨(dú)立的,他們只是擁有相同的值而已,是完全獨(dú)立的拷貝,互不干涉。

引用數(shù)據(jù)類型包括:Function, Array, Object 等等除了基本數(shù)據(jù)類型之外的數(shù)據(jù)。引用數(shù)據(jù)類型是保存在堆內(nèi)存當(dāng)中的。

JS 不允許直接操作對象的內(nèi)存空間,所以引用數(shù)據(jù)類型是通過存儲(chǔ)在變量處的值,也就是一個(gè)指針(point),指向存儲(chǔ)對象的內(nèi)存地址,從而進(jìn)行訪問的。

let obj1 = new Object();
var obj2 = obj1;

JavaScript按值傳遞

當(dāng)把引用類型的變量 obj1 賦給另一個(gè)變量 obj2 后,obj2 接受的其實(shí)是引用類型數(shù)據(jù)的內(nèi)存地址指針。所以,判斷兩個(gè)引用類型是否相等,其實(shí)比較的是內(nèi)存地址是否相等。

二、按值傳遞
var num = 1;
function foo(param) {
    param = 2;
}
foo(num);
console.log(num); // num 值仍為1, 并沒有受 param = 2 賦值影響

以上代碼:

按值傳遞每次傳遞參數(shù)時(shí),都會(huì)拷貝一份副本到函數(shù)內(nèi)部,拷貝前后的兩個(gè)值互不影響。

二、“按引用傳遞”
var obj = {
    num: 1
};

function foo(o) {
    o.num = 2;
    console.log(obj.num);  // 2
}

foo(obj);
console.log(obj.num); // 2

以上代碼,foo 函數(shù)把 obj 對象作為實(shí)參,執(zhí)行完畢后把 obj 對象的 num 屬性給改變了,說明參數(shù) o 對象 和 外部變量 obj 對象是同一個(gè)對象。說好的按值傳遞呢,怎么還是把原來的對象給改變了呢。

三、按共享傳遞

再看下面這段代碼:

var obj = {
    num: 1
};

function foo(o) {
    o = 100;
}

foo(obj);
console.log(obj.num);  // 1

如果是按引用傳遞的話,按理來說 obj 對象會(huì)被改變會(huì) 100 才對。

準(zhǔn)確的說,JS中的基本類型按值傳遞,對象類型按共享傳遞的(call by sharing,也叫按對象傳遞、按對象共享傳遞)

在共享傳遞中對函數(shù)形參的賦值,不會(huì)影響實(shí)參本身的值。

所以,形參引用的對象是同一個(gè),由于對象是可變的(mutable),修改形參中對象的屬性值,會(huì)影響到原本對象的屬性值。

按引用傳遞是傳遞對象的引用,而按共享傳遞是傳遞對象的拷貝的副本,所以副本本身無法直接修改。而拷貝副本也是一種拷貝,所以也被認(rèn)為是按值傳遞。

基本類型本身是按值傳遞,具有不可變性(immutable),對基本類型的修改,實(shí)質(zhì)上都是在棧內(nèi)存中創(chuàng)建了新的值。

復(fù)習(xí)鞏固:

var obj = { num : 0 };
obj.num = 100;
var o = obj;
o.num = 1;
obj.num; // 1, 被修改
o = true;
obj.num; // 1,  o 是對象的一個(gè)拷貝,對 o 本身的修改,不會(huì)改變 obj 對象本身的值。
總結(jié)

JavaScript 中參數(shù)的傳遞只有按值傳遞,而對于引用類型的傳遞,是一種共享傳遞,傳遞的是數(shù)據(jù)類型的拷貝副本,雖然引用的是同一個(gè)對象,但是無法通過改變形參來改變實(shí)參本身。

以上就是JavaScript按值傳遞的方法,代碼示例簡單明了,如果在日常工作遇到此問題。通過這篇文章,希望你能有所收獲,更多詳情敬請關(guān)注億速云行業(yè)資訊頻道!

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

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

AI