理解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
- 理解JavaScript函数参数
- javascript 中函数参数的理解
- 深入理解JavaScript函数参数(推荐)
- 深入理解JavaScript函数参数(推荐)
- 理解javascript中所有的函数参数是按值传递
- JavaScript深入理解函数参数列表及“不存在重载”
- javascript参数的理解
- javascript理解参数
- Gabor函数参数理解
- 理解函数参数
- read()函数参数理解
- javascript 函数参数 个数
- javascript获取函数参数
- JavaScript函数参数个数
- Javascript函数参数
- [Javascript] 函数参数讨论
- JavaScript函数参数个数
- javascript函数参数
- git cherry-pick 使用指南
- ngx_http_request_t结构体
- Java 的初学之环境安装篇
- 设计模式的基础篇相关知识,简单易懂。
- HPE收购很忙,不如一起来聊聊Nimble Storage
- 理解JavaScript函数参数
- Git笔记(三)——[cherry-pick, merge, rebase]
- 一头扎进Spring源码之ContextLoader
- OC中用小括号()包裹着花括号{}的写法
- GB28181技术基础之5
- Git笔记(二)——[diff, reset]
- 记录一下自己遇到的问题
- C# .NET更智能的数据库操作封装项目
- 关于程序员转行的一点思考