function changeStuff(a, b, c)
{
a = a * 10;
b.item = "changed";
c = {item: "changed"};
}
var num = 10;
var obj1 = {item: "unchanged"};
var obj2 = {item: "unchanged"};
changeStuff(num, obj1, obj2);
console.log(num);
console.log(obj1.item);
console.log(obj2.item);
在JavaScript中很有趣。考虑以下示例:
function changeStuff(a, b, c) { a = a * 10; b.item = "changed"; c = {item: "changed"}; } var num = 10; var obj1 = {item: "unchanged"}; var obj2 = {item: "unchanged"}; changeStuff(num, obj1, obj2); console.log(num); console.log(obj1.item); console.log(obj2.item);这将产生以下输出:
obj1根本不是引用,那么改变obj1.item对函数外部的obj1没有影响。num将为100,obj2.item将为"changed"。相反,num保持为10,obj2.item仍然为"unchanged"。实际上,情况是传递的项是按值传递的。但是按值传递的项本身是一个引用。 从技术上讲,这被称为共享调用。
在实际应用中,这意味着如果更改参数本身(如
num和obj2),那不会影响传入参数的项。但是,如果更改参数的内部,那将会传播回来(如obj1)。