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保持“不变”。相反,情况是传入的项是按值传递的。但是按值传递的项本身就是一个引用。 从技术上讲,这称为共享呼叫。
实际上,这意味着如果您更改参数本身(如
num和obj2),则不会影响输入到范围。但是,如果您更改参数的内部,它将向上传播(与obj1一样)。