加入收藏 | 设为首页 | 会员中心 | 我要投稿 驾考网 (https://www.jiakaowang.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 教程 > 正文

简述JavaScript函数参数的可修改性问题

发布时间:2023-08-15 14:30:26 所属栏目:教程 来源:
导读:一道笔试题思考而来的,通常情况下没人会在函数内部修改参数值。这里仅拿出来讨论,有三种方式可以修改。

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

代码如下:

function f1(a) {

alert(a);

a = 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。
 
 

(编辑:驾考网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章