3 回答

TA貢獻(xiàn)1817條經(jīng)驗(yàn) 獲得超6個(gè)贊
第一個(gè)代碼片段創(chuàng)建一個(gè)局部變量number作為函數(shù)參數(shù),它隱藏同名的外部變量。
由于 JavaScript 是按值傳遞的,因此新變量會(huì)被賦予 value 100。由于變量的作用域?yàn)楹瘮?shù)change,因此當(dāng)您更新賦值時(shí),函數(shù)作用域中定義的變量也會(huì)更新。
let number = 100
function change(number) {
//This is the variable scoped to the function
number = number * 10;
}
//This is the variable defined in the global scope
change(number);
console.log(number);
在第二個(gè)片段中,您直接更新number函數(shù)外部的定義change,因此您會(huì)看到更新的值。

TA貢獻(xiàn)1797條經(jīng)驗(yàn) 獲得超6個(gè)贊
在第一個(gè)代碼片段中,參數(shù)隱藏了變量number- 它創(chuàng)建了一個(gè)名為的變量,number該變量是函數(shù)的本地變量,然后更新它。
在第二個(gè)片段中,甚至沒有使用參數(shù),而是number直接更新變量。您可以編寫不帶參數(shù)的相同函數(shù):
let number = 100
function change() { // No parameter!
number = number * 10;
}
change();
console.log(number);

TA貢獻(xiàn)1856條經(jīng)驗(yàn) 獲得超11個(gè)贊
您可以使用與參數(shù)同名的變量,因?yàn)?strong>無論如何,值都是相同的,除非同名變量的值與參數(shù)不同,這是因?yàn)楹瘮?shù)的參數(shù)已被聲明為該函數(shù)的本地參數(shù)。
添加回答
舉報(bào)