——《JavaScript高级程序设计(第3版)》P71
参数为引用类型时,是按值传递的。
function setName(obj){
obj.name = "zhangsan";
obj = new Object();
obj.name = "lisi";
}
var person = new Object();
setName(person);
alert(person.name); // "zhangsan"
在函数体里,给参数obj重新赋值新的对象后,同时将其name属性设置为"lisi",在函数内部修改参数的值,但原始的引用依然保持不变,person的name属性没有被改写。实际上,当函数内部重写obj时,这个变量引用的就是一个局部对象了。而这个局部对象会在函数执行完毕后立即被销毁。
引申:关于函数的复制问题:
var fn1 = function(){
/* xxx */
}
var fn2 = fn1;
——《JavaScript高级程序设计(第3版)》P110
var sum = function(a,b){
return a+b;
}
var sum1 = sum;
sum = function(a,b){
return a-b;
}
console.log(sum1(3,2)); //5
sum和sum1都指向同一个函数,将sum设置成其他的东西,并不影响sum1的正常调用。(函数的复用,互不影响)
切记,函数的名字仅仅是一个包含指针的变量而已。像递归调用、this指向等问题,函数名变量指向其他值后,就会出现不同的结果。