【发布时间】:2022-11-26 07:16:45
【问题描述】:
我正在寻找一些很好的综合阅读材料,了解 JavaScript 何时按值传递某些内容,何时按引用传递以及修改传递的项目何时影响函数外部的值以及何时不影响。我还对通过引用还是通过值分配给另一个变量感兴趣,以及它是否遵循与作为函数参数传递不同的规则。
我已经做了很多搜索并找到了很多具体的例子(其中很多都在 SO 上),我可以从中开始拼凑出真正的规则,但我还没有找到一个写得很好的文件描述了这一切。
此外,语言中是否有方法可以控制某些内容是按引用还是按值传递?
以下是我想了解的一些问题类型。这些只是例子——我实际上是想了解语言所遵循的规则,而不仅仅是特定例子的答案。但是,这里有一些例子:
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