打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
js中arguments的用法

1、在JavaScript中,arguments对象是比较特别的一个对象,实际上是当前函数的一个内置属性。arguments非常类似Array,但实际上又不是一个Array实例。可以通过如下代码得以证实(当然,实际上,在函数funcArg中,调用arguments是不必要写成funcArg.arguments,直接写arguments即可)。

Array.prototype.testArg = 'test';
function funcArg() {
    alert(funcArg.arguments.testArg);  
    alert(funcArg.arguments[0]);
}

alert(new Array().testArg); // result: 'test'
funcArg(10);                // result: 'undefined'  '10'


2、arguments对象的长度是由实参个数而不是形参个数决定的。形参是函数内部重新开辟内存空间存储的变量,但是其与arguments对象内存空间并不重叠。对于arguments和值都存在的情况下,两者值是同步的,但是针对其中一个无值的情况下,对于此无值的情形值不会得以同步。如下代码可以得以验证。

function f(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);

但是实参和形参之间是相互影响的,比如如果修改了 arguments[0]='hello'那么a 的值也会变成hello.

3、由JavaScript中函数的声明和调用特性,可以看出JavaScript中函数是不能重载的

根据其他语言中重载的依据:'函数返回值不同或形参个数不同',我们可以得出上述结论:

第一:Javascript函数的声明是没有返回值类型这一说法的;

第二:JavaScript中形参的个数严格意义上来讲只是为了方便在函数中的变量操作,实际上实参已经存储在arguments对象中了。

另外,从JavaScript函数本身深入理解为什么JavaScript中函数是不能重载的:在JavaScript中,函数其实也是对象,函数名是关于函数的引用,或者说函数名本身就是变量。对于如下所示的函数声明与函数表达式,其实含以上是一样的(在不考虑函数声明与函数表达式区别的前提下),非常有利于我们理解JavaScript中函数是不能重载的这一特性。

function f(a){
    return a + 10;
}

function f(a){
    return a - 10;
}

// 在不考虑函数声明与函数表达式区别的前提下,其等价于如下

var f = function(a){
    return a + 10;
}

var f = function(a){
    return a - 10;
}

Javascript并没有重载函数的功能,但是Arguments对象能够模拟重载。

function hi(){
if(arguments[0]=='andy'){
return;
}
alert(arguments[
0]);

4、arguments对象中有一个非常有用的属性:callee。arguments.callee返回此arguments对象所在的当前函数引用。在使用函数递归调用时推荐使用arguments.callee代替函数名本身。表示对函数对象本身的引用,也就是所指定的Function 对象的正文,这有利于实现无名函数的递归或者保证函数的封装性。

function count(a){
    if(a==1){
        return 1;
    }
    return a + arguments.callee(--a);
}

var mm = count(10);
alert(mm);

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
javascript之Function类型
js中arguments的作用
Javascript中的变量以及如何定义静态变量 | 盛夏莲花
全面理解javascript的caller,callee,call,apply概念
Javascript函数声明与递归调用
前端入门12-JavaScript语法之函数
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服