Javascript中的值引用是指變量存儲(chǔ)的是值在內(nèi)存中的地址,而不是值本身。換句話說,當(dāng)變量通過賦值或傳遞給函數(shù)等操作時(shí),變量存儲(chǔ)的僅僅是指向值在內(nèi)存中的指針。
下面看一個(gè)例子:
let a = [1, 2, 3]; let b = a; b[0] = 100; console.log(a); // [100, 2, 3]
在這個(gè)例子中,a變量被賦予一個(gè)數(shù)組[1, 2, 3],b變量又被賦成了a。如果我們修改b的第一個(gè)元素,a也會(huì)受到影響。
再看一個(gè)例子:
let c = { x: 10, y: 20 }; let d = c; d.x = 100; console.log(c); // { x: 100, y: 20 }
在這個(gè)例子中,c變量被賦予一個(gè)對(duì)象{x: 10, y: 20},d變量又被賦成了c。如果我們修改d的屬性x,c也會(huì)受到影響。
可以看出,數(shù)組和對(duì)象都是引用類型,變量存儲(chǔ)的僅僅是指向值在內(nèi)存中的指針。因此在JavaScript中,當(dāng)我們傳遞一個(gè)數(shù)組或?qū)ο蠼o函數(shù)時(shí),函數(shù)獲得的是指向該數(shù)組或?qū)ο蟮闹羔槪皇菑?fù)制數(shù)組或?qū)ο蟮娜績(jī)?nèi)容。
下面看一個(gè)傳遞對(duì)象給函數(shù)的例子:
function changeObj(obj) { obj.x = 100; } let e = { x: 10, y: 20 }; changeObj(e); console.log(e); // { x: 100, y: 20 }
在這個(gè)例子中,我們把對(duì)象e傳給了函數(shù)changeObj。在函數(shù)內(nèi)部,我們修改了它的屬性x,而外部變量e也被修改了。這是因?yàn)楹瘮?shù)獲得的是指向該對(duì)象的指針。
總之,在JavaScript中,使用引用類型變量時(shí)要特別小心。如果一個(gè)變量的值是數(shù)組或?qū)ο螅敲粗皇谴鎯?chǔ)了該數(shù)組或?qū)ο蟮闹羔槨R虼耍?dāng)我們操作該變量的時(shí)候,實(shí)際上是操作數(shù)組或?qū)ο笤趦?nèi)存中的地址。
最后,我們需要注意的是,基本類型和引用類型的賦值是不同的。基本類型的賦值是值復(fù)制,而引用類型的賦值是指針復(fù)制。因此,基本類型的修改不會(huì)影響其他變量,而引用類型的修改會(huì)影響所有指向該對(duì)象的變量。