理解JavaScript函数参数

本文深入探讨了JavaScript中函数参数的工作原理,重点介绍了如何利用arguments对象处理不同数量和类型的参数,以实现方法重载的效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

   js中函数参数很有意思,不在乎你传入几个参数,也不在你传入参数的类型,如此神奇。其原因是在js内部参数是用一个数组表示的,函数内部接收到的始终是这个数组。在函数体内部使用arguments对象来访问这个数组,从而获取到参数。严格的来讲,arguments对象并不是一个数组,只是数据结构类似数组,并使用方括号的语法访问每一个元素和length获取其长度。

<script>
function test(){
  alert(arguments.length);
}
test("a");//1
test("a",1);//2
test("a",1,new Object())//3
</script>
   开发过程中根据函数参数传入的个数和类型不同,去执行不同的代码,来弥补js没有方法重载的遗憾

function test1(a,b){
	arguments[1]=100;
	alert(arguments[0]+b);
}
test1(10,10);//输出110
test1(10);//输出NaN
   对于test1这个函数,当传入两个参数,arguments[1]=100;会将b的重新赋值100,在arguments行为中,他的值和对应的参数的值永远保持同步,因此输出110;可是当传入一个参数的时候,没有传递值的命名参数被自动赋予undefined,并且由于arguments对象对应的类数组的长度是由传入的参数个数决定,并非由定义函数时命名参数决定,arguments[1]设置的值不会对应到参数b,因此输出NaN。

*在js中所有参数传递的都是值,不可能通过引用传递参数。切记!


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值