函数传递参数——值的复制

——《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指向等问题,函数名变量指向其他值后,就会出现不同的结果。

你可能感兴趣的:(js)