欢迎来到代码驿站!

JavaScript代码

当前位置:首页 > 网页前端 > JavaScript代码

浅谈JavaScript函数参数的可修改性问题

时间:2021-07-19 07:59:57|栏目:JavaScript代码|点击:

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

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。

上一篇:Three.JS实现三维场景

栏    目:JavaScript代码

下一篇:js实现每日自动换一张图片的方法

本文标题:浅谈JavaScript函数参数的可修改性问题

本文地址:http://www.codeinn.net/misctech/159095.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有