js中传递参数问题

ECMAScript中所有函数的参数都是按值传递
访问变量有按值和按引用两张方式,而参数只能按值传递
例子:
function addTen(num){
num  += 10;  //在函数内部,参数num的值被加上了10,但这一变化不会影响函数外部的count变量
return num;
}
var count = 20;
var result = addTen(count);
alert(count);   //20,没有变化,如果是按引用传递那会变成30

alert(result); //30


如果使用对象,就不是很好理解


例子:
function setName(obj){
obj.name = "Nicholas";
obj = new Object();
obj.name = "Grey";
}

var person = new Object();
setName(person);

alert(person.name); //"Nicholas"

如果person是按引用传递的,nameperson就会自动被修改为指向其name属性值为“Grey”的新对象。

但是,结果显示为“Nicholas”。这说明即使在函数内部修改了参数的值,但原始的引用仍然保持未变。

实际上,当在函数内部重写obj时,这个变量引用的就是一个局部对象。而这个局部对象会在函数执行完毕后立即被销毁。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值