我写了如下代码:
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/