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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值