Javascript Arguments对象
2015-10-17 04:31
429 查看
1、在JavaScript中,arguments对象是比较特别的一个对象,实际上是当前函数的一个内置属性。arguments非常类似Array,但实际上又不是一个Array实例。可以通过如下代码得以证实(当然,实际上,在函数funcArg中,调用arguments是不必要写成funcArg.arguments,直接写arguments即可)。
2、arguments对象的长度是由实参个数而不是形参个数决定的。形参是函数内部重新开辟内存空间存储的变量,但是其与arguments对象内存空间并不重叠。对于arguments和值都存在的情况下,两者值是同步的,但是针对其中一个无值的情况下,对于此无值的情形值不会得以同步。如下代码可以得以验证。
3、由JavaScript中函数的声明和调用特性,可以看出JavaScript中函数是不能重载的。
根据其他语言中重载的依据:"函数返回值不同或形参个数不同",我们可以得出上述结论:
第一:Javascript函数的声明是没有返回值类型这一说法的;
第二:JavaScript中形参的个数严格意义上来讲只是为了方便在函数中的变量操作,实际上实参已经存储在arguments对象中了。
另外,从JavaScript函数本身深入理解为什么JavaScript中函数是不能重载的:在JavaScript中,函数其实也是对象,函数名是关于函数的引用,或者说函数名本身就是变量。对于如下所示的函数声明与函数表达式,其实含以上是一样的(在不考虑函数声明与函数表达式区别的前提下),非常有利于我们理解JavaScript中函数是不能重载的这一特性。
4、arguments对象中有一个非常有用的属性:callee。arguments.callee返回此arguments对象所在的当前函数引用。在使用函数递归调用时推荐使用arguments.callee代替函数名本身。
如下:
Array.prototype.testArg="test";
functionfuncArg(){
alert(funcArg.arguments.testArg);
alert(funcArg.arguments[0]);
}
alert(newArray().testArg);//result:"test"
funcArg(10);//result:"undefined""10"
2、arguments对象的长度是由实参个数而不是形参个数决定的。形参是函数内部重新开辟内存空间存储的变量,但是其与arguments对象内存空间并不重叠。对于arguments和值都存在的情况下,两者值是同步的,但是针对其中一个无值的情况下,对于此无值的情形值不会得以同步。如下代码可以得以验证。
functionf(a,b,c){
alert(arguments.length);//result:"2"
a=100;
alert(arguments[0]);//result:"100"
arguments[0]="qqyumidi";
alert(a);//result:"qqyumidi"
alert(c);//result:"undefined"
c=2012;
alert(arguments[2]);//result:"undefined"
}
f(1,2);
3、由JavaScript中函数的声明和调用特性,可以看出JavaScript中函数是不能重载的。
根据其他语言中重载的依据:"函数返回值不同或形参个数不同",我们可以得出上述结论:
第一:Javascript函数的声明是没有返回值类型这一说法的;
第二:JavaScript中形参的个数严格意义上来讲只是为了方便在函数中的变量操作,实际上实参已经存储在arguments对象中了。
另外,从JavaScript函数本身深入理解为什么JavaScript中函数是不能重载的:在JavaScript中,函数其实也是对象,函数名是关于函数的引用,或者说函数名本身就是变量。对于如下所示的函数声明与函数表达式,其实含以上是一样的(在不考虑函数声明与函数表达式区别的前提下),非常有利于我们理解JavaScript中函数是不能重载的这一特性。
functionf(a){
returna+10;
}
functionf(a){
returna-10;
}
//在不考虑函数声明与函数表达式区别的前提下,其等价于如下
varf=function(a){
returna+10;
}
varf=function(a){
returna-10;
}
4、arguments对象中有一个非常有用的属性:callee。arguments.callee返回此arguments对象所在的当前函数引用。在使用函数递归调用时推荐使用arguments.callee代替函数名本身。
如下:
functioncount(a){
if(a==1){
return1;
}
returna+arguments.callee(--a);
}
varmm=count(10);
alert(mm);
相关文章推荐
- Ember.js 入门指南——model简介2
- Ember.js 入门指南——model简介1
- JS学习笔记(02)——节点对象
- PhantomJS基础及示例
- json格式化
- PhantomJS
- 用js写九九乘法表
- 如何用js写选项卡
- jsp之c标签用法实例分析
- JSP生成WORD文档,EXCEL文档及PDF文档的方法
- JavaScript实现的背景自动变色代码
- JavaScript实现点击按钮切换网页背景色的方法
- JS实现的网页背景闪电闪烁效果代码
- ionic 性能优化 (持续更新)
- Ember.js 入门指南——model简介1
- Ember.js 入门指南——model简介2
- 各个JSON技术的比较
- JavaScript之命名空间模式 浅析
- 关于history.js的使用
- casperjs中getPageContent()方法及getHTML()方法的使用