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中所有参数传递的都是值,不可能通过引用传递参数。切记!
转载请注明原文地址: https://ju.6miu.com/read-7420.html