javascript - 函数(a,b){ a = b; } 不会改变 javascript 中 a 的值

标签 javascript function reference arguments variable-assignment

我写了如下代码:

function setAtoB(a, b) {
    console.log('entered function');
    a = b;
}
var x = {};
var y = {'t':3};
setAtoB(x, y);
console.log(x);

然后我得到这样的输出:

entered function
{}

在我看来 x 应该是 {'t':3}。有谁知道为什么它仍然是 {},以及我如何在函数内赋值?

最佳答案

在 setAtoB 函数中,您将 a 替换为 b,这会中断 a 对调用堆栈中上一级调用者的引用。将对象传递给函数时,您可以替换它们的属性而不会破坏该链接,但是当您执行任何类型的重新分配时,该链接就会中断并创建一个新对象。

例如,如果您只替换属性,则保留引用:

function setAtoB(a, b) {
    console.log('entered function');
    a.t = b.t;
}
var x = {};
var y = {'t':3};
setAtoB(x, y);
console.log(x);    // output: Object {t: 3} 

关于javascript - 函数(a,b){ a = b; } 不会改变 javascript 中 a 的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24478599/

相关文章:

function - 解释器中的 Perl 6 函数参数语法 (REPL)

reference - 了解 Vec<T> 的调试实现

vba - 在 VBA 中更新页码

javascript - .addHitRegion() 在 Chrome 中不起作用

javascript - 意外的标记 。运行 server.js 时

javascript - 防止 jquery ajax 加载时继续循环

javascript - console.log 在 CasperJS 的 setTimeout 评估中不起作用

Javascript onclick 改变 id img

javascript - 理解 Underscore 的 _.each

java - 提前引用变量?