【发布时间】:2011-09-30 03:26:12
【问题描述】:
我正在寻找一些很好的综合阅读材料,了解 JavaScript 何时通过值传递,何时通过引用传递,何时修改传递的项目会影响函数外部的值,何时不影响。我还对通过引用与按值分配给另一个变量的时间以及是否遵循与作为函数参数传递不同的规则感兴趣。
我做了很多搜索,找到了很多具体的例子(其中很多都在这里),我可以从中开始拼凑真正的规则,但我还没有找到一个,嗯描述这一切的书面文件。
此外,语言中是否有方法来控制是通过引用传递还是通过值传递?
以下是我想了解的一些问题类型。这些只是例子——我实际上是想了解语言所遵循的规则,而不仅仅是具体例子的答案。但是,这里有一些例子:
function f(a,b,c) {
a = 3;
b.push("foo");
c.first = false;
}
var x = 4;
var y = ["eeny", "miny", "mo"];
var z = {first: true};
f(x,y,z);
x、y 和 z 的内容何时会在所有不同类型的 f 范围之外发生变化?
function f() {
var a = ["1", "2", "3"];
var b = a[1];
a[1] = "4";
// what is the value of b now for all possible data types that the array in "a" might hold?
}
function f() {
var a = [{yellow: "blue"}, {red: "cyan"}, {green: "magenta"}];
var b = a[1];
a[1].red = "tan";
// what is the value of b now and why?
b.red = "black";
// did the value of a[1].red change when I assigned to b.red?
}
如果我想制作一个完全独立的对象副本(没有任何引用),那么最佳做法是什么?
【问题讨论】:
标签: javascript reference pass-by-reference pass-by-value