JavaScript函数参数的可修改性

函数参数修改探讨
本文讨论了在JavaScript中如何修改函数的参数值,并提供了三种方法:直接修改形参、通过arguments对象修改以及在函数内部声明与形参同名的局部变量。

一道笔试题思考而来的,通常情况下没人会在函数内部修改参数值。这里仅拿出来讨论,有三种方式可以修改。

1,直接修改函数声明时的形参


1 function f1(a) {
2      alert(a);
3      a = 1; //修改形参a
4      alert(1 === a);
5      alert(1 === arguments[0]);
6 }
7 f1(10);

函数f1定义了参数a,调用时传参数10,先弹出10,修改a为1,弹出两次true,a和arguments[0]都为1了。

 

2,通过函数内部的arguments对象修改


1 function f2(a) {
2      alert(a);
3      arguments[0] = 1; //修改arguments
4      alert(1 === a);
5      alert(1 === arguments[0]);
6       
7 }

效果同函数f1。

 

3,函数内部声明的局部变量与形参同名


1 function f3(a) {
2      alert(a);
3      var a = 1; //声明局部变量a且赋值为1
4      alert(1 === a);
5      alert(arguments[0]);
6 }
7 f3(10);

 函数f3定义了形参a,函数内部声明局部变量a同时赋值为1,但这里的a仍然是参数a,从最后弹出的arguments[0]被修改为1可以证明。


4,如果只是声明局部变量a,却不赋值,情况又不一样了


1 function f3(a) {
2      var a; //仅声明,不赋值
3      alert(a);
4      alert(arguments[0]);
5 }
6 f3(10);

这时候弹出的都是10,而不是undefined。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值