理解JavaScript函数参数

    xiaoxiao2021-03-25  142

       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

    最新回复(0)