我最近在 JS 中遇到了一个令人讨厌的问题。
假设我们将一个映射、一个对象数组传递给函数 f。
var o=[{a:0}];
function f(a){
for(var i in a){
if (a.hasOwnProperty(i)){
a[i]=null;
}
}
return a;
};
var outp=f(o);
alert(outp[0]+" === "+o[0]+" : "+(outp[0]===o[0]));
// here we expect loose equality, and equality in type,
//furthermore it should identically equal as well, and we got right!
但是,我们不能将对象的全部责任作为参数传递给函数,就像在函数范式中一样o=(function(o){return o})()
,因为没有引用对 o 的任何修改!
var o=[];
function ff(a){
return (a=undefined);
};
var outp=ff(o);
alert(outp+" === "+o.constructor+" : "+(outp===o));
// here we expect true, but we got false!
为什么在第二个用例中上述参考丢失和可能不同的参考处理,尽管在这两种情况下,函数都将数组参数放在 0. 位置?