首页 >

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

web前端|js教程浅谈JavaScript函数参数的可修改性问题【javascript】
JavaScript,函数参数
web前端-js教程
一道笔试题思考而来的,通常情况下没人会在函数内部修改参数值。这里仅拿出来讨论,有三种方式可以修改。

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

新闻类app服务端源码,vscode 显示菜单,k3b ubuntu,以色列tomcat,点餐sqlite,建设网站要服务器吗,fckeditor自动排版插件,前端框架树图,聚焦网络爬虫原理,php型号,seo优化及推广,mp4网站代码,网页分享客服代码,dz首页模板,移动端h5页面模版,狼奔权限管理系统2.3,短时傅里叶变换 matlab程序lzw
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对象修改

html5视频点播网站源码,安装ubuntu其他选项,tomcat限制用户数量,养什么爬虫好玩,虚拟商品自动发货系统php源码,seo985lzw
function f2(a) { 
alert(a);
arguments[0] = 1;//修改arguments
alert(1 === a);
alert(1 === arguments[0]);
日记类型网站源码,ubuntu放开80端口,爬虫馆赚钱吗,php 阻止allert,全国seo收入lzw
}
效果同函数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】
  • python中函数传参详解
  • python中函数传参详解 | python中函数传参详解 ...

    浅谈JavaScript函数参数的可修改性问题【javascript】
  • javascript,php获取函数参数对象的代码【PHP】
  • javascript,php获取函数参数对象的代码【PHP】 | javascript,php获取函数参数对象的代码【PHP】 ...

    浅谈JavaScript函数参数的可修改性问题【javascript】
  • 深入讨论Python函数的参数的默认值所引发的问题的原因
  • 深入讨论Python函数的参数的默认值所引发的问题的原因 | 深入讨论Python函数的参数的默认值所引发的问题的原因 ...