理解JavaScript函数参数

来源:互联网 发布:绿色建筑软件 编辑:程序博客网 时间:2024/05/17 22:17

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

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

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

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


0 0
原创粉丝点击