手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >浅谈JavaScript函数参数的可修改性问题
浅谈JavaScript函数参数的可修改性问题
摘要:一道笔试题思考而来的,通常情况下没人会在函数内部修改参数值。这里仅拿出来讨论,有三种方式可以修改。1,直接修改函数声明时的形参复制代码代码如...

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

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

复制代码 代码如下:

function f1(a) {

alert(a);

a = 1;//修改形参a

alert(1 === a);

alert(1 === arguments[0]);

}

f1(10);

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

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

复制代码 代码如下:

function f2(a) {

alert(a);

arguments[0] = 1;//修改arguments

alert(1 === a);

alert(1 === arguments[0]);

}

效果同函数f1。

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

复制代码 代码如下:

function f3(a) {

alert(a);

var a = 1;//声明局部变量a且赋值为1

alert(1 === a);

alert(arguments[0]);

}

f3(10);

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

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

复制代码 代码如下:

function f3(a) {

var a;//仅声明,不赋值

alert(a);

alert(arguments[0]);

}

f3(10);

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

【浅谈JavaScript函数参数的可修改性问题】相关文章:

深入理解JavaScript中的对象

JavaScript判断数组是否包含指定元素的方法

Javascript实现div层渐隐效果的方法

JavaScript实现将UPC转换成ISBN的方法

javascript实现动态改变层大小的方法

JavaScript对传统文档对象模型的支持

JavaScript实现鼠标滑过处生成气泡的方法

使用JavaScript刷新网页的方法

JavaScript获得url查询参数的方法

JavaScript实现带标题的图片轮播特效

精品推荐
分类导航