js的arguments到底是什么?

news/2024/7/19 13:29:06 标签: js, arguments

 

arguments">类数组对象:arguments

总所周知,js是一门相当灵活的语言。当我们在js中在调用一个函数的时候,我们经常会给这个函数传递一些参数,js把传入到这个函数的全部参数存储在一个叫做arguments的东西里面,那么这到底是什么东西?

js中万物皆对象,甚至数组字符串函数都是对象。所以这个叫做arguments的东西也是个对象,而且是一个特殊的对象,它的属性名是按照传入参数的序列来的,第1个参数的属性名是’0’,第2个参数的属性名是’1’,以此类推,并且它还有length属性,存储的是当前传入函数参数的个数,很多时候我们把这种对象叫做类数组对象。类数组对象和数组都是对象这个妈生的,但是数组是大哥比类数组对象多了很多其他的玩具(方法),类数组对象只是长得很像数组的弟弟而已。

慢着,刚刚不是说数组也是对象吗,现在这个类数组对象又是什么? 没办法,js就是这么的灵活。这个类数组对象不仅存储给函数传入的参数,也具有一些其他的属性,等下会一一道来。

因为类数组对象和数组有很多的共性,所以我们经常可以用call方法,让类数组对象也使用的数组的一些方法,就是让这个弟弟去玩哥哥的玩具,比如……,还是不扯远了,这篇文章只是说什么是arguments,想知道更多关于对象如何借调数组方法的话,请参考这篇文章。

下面举个栗子:

function add() {
    if( arguments.length == 2 ){
        return arguments[0] + arguments[1];
    }else{
        return '传入参数不合法';
    }
}

console.log( add(2,3) );
console.log( add(1,2,3) );

看看结果:

结果

最后我们还可以看到arguments还有一个叫做callee的属性,这个属性是表示的是当前函数的一个引用,简单点说,这个属性里面存储的我们调用的这个函数的代码,实在无法理解的时候,又到了console.log大显身手的时候了。

最后我们还可以看到arguments还有一个叫做callee的属性,这个属性是表示的是当前函数的一个引用,简单点说,这个属性里面存储的我们调用的这个函数的代码,实在无法理解的时候,又到了console.log大显身手的时候了。

function showcallee() {
    var a = '这里是代码';
    var b = '这是另一段代码';
    var c = a + b;

    console.log(arguments.callee);

    return c;
}
showcallee();

结果

看到结果的你是不是和我一样惊呆了呢,这不就是我写的代码吗,arguments.callee完完整整的把这个函数的这段代码返回了。


arguments的一些妙用">arguments的一些妙用

1.利用arguments实现方法的重载

下面我们利用arguments对象来实现一个参数相加的函数,不论传入多少参数都行,将传入的参数相加后返回。

function add() {
    var len = arguments.length,
        sum = 0;
    for(;len--;){
        sum += arguments[len];
    }
    return sum;
}

console.log( add(1,2,3) );   //6
console.log( add(1,3) );     //4
console.log( add(1,2,3,5,6,2,7) );   //26

由于js是一种弱类型的语言,没有重载机制,当我们重写函数时,会将原来的函数直接覆盖,这里我们能利用arguments,来判断传入的实参类型与数量进行不同的操作,然后返回不同的数值。

2.利用arguments.callee实现递归

先来看看之前我们是怎么实现递归的,这是一个结算阶乘的函数

function factorial(num) { 
    if(num<=1) { 
        return 1; 
    }else { 
        return num * factorial(num-1); 
    } 
} 

但是当这个函数变成了一个匿名函数时,我们就可以利用callee来递归这个函数

function factorial(num) { 
    if(num<=1) { 
        return 1; 
    }else { 
        return num * arguments.callee(num-1); 
    } 
} 

这个方法虽然好用,但是有一点值得注意,ECMAScript4中为了限制js的灵活度,让js变得严格,新增了严格模式,在严格模式中我们被禁止不使用var来直接声明一个全局变量,当然这不是重点,重点是arguments.callee这个属性也被禁止了。不过这都不是事儿,ES6为我们新增了很多好用的变量声明方式和新的语法糖,作为一个时髦的前端,我们赶紧学习一些ES6的新语法吧。


http://www.niftyadmin.cn/n/1529132.html

相关文章

mysql触发器 for each row解释

mysql触发器 for each row解释 2018年04月20日 16:35:36 阅读数&#xff1a;173 create trigger mytrigger alert insert on t_a for each row begin insert into t_b set namenew.name, set numbernew number; 程序体或者是 set namenew.name; set numbernew.number; ins…

将类数组对象转化成数组对象的几种方法

一、Array.prototype.slice.call(arrayLike) 原理是数组的slice()方法可以从已有数组中返回一个新数组&#xff0c;它可以接受两个参数arr.slice(start,end),第一个参数规定从何处开始选取&#xff0c;第二个参数表示从何处选取结束&#xff0c;如果不传参将返回原数组的一个副…

indexOf( ) 返回字符串值在字符串中首次出现的位置

作用&#xff1a; 1. 可以检测字符串的位置。 2. 检测字符是否出现在字符串中&#xff08;当返回结果为-1时&#xff0c;表示该字符不存在于字符串中&#xff09; ***返回字符最后出现的位置 lastIndexOf( ) http://www.w3school.com.cn/jsref/jsref_lastIndexOf.asp

String.charCodeAt() 返回指定位置的字符unicode 编码

str"ling"return str.charCodeAt(0) //返回str 的第0个字符的编码号&#xff1a;108&#xff1b;return str.charCodeAt(0) //返回str 的第0个字符的编码号&#xff1a;105&#xff1b;

String.fromCharCode() 返回指定unicode编码对应的字符

document.write(String.fromCharCode(72,69,76,76,79))//结果:HELLO

PreparedStatement 中的setString

PreparedStatement 中的setString 2012年09月25日 16:03:32 阅读数&#xff1a;914 如果使用了setString(),则会自动为你的变量添加单引号 比如&#xff1a; String str"nowdate"; ...setString(1,str); 这样在生成的SQL中&#xff0c;str会变为&#xff1a; n…

$().each和$.each的区别

1.$(selector).each(function(index,element))2.$.each(dataresource,function(index,element)) 接下来就对这两个函数做深入的探讨&#xff1a; 1.$(selector).each(function(index,element)) 作用&#xff1a;在dom处理上面用的较多 &#xff08;html 元素、节点&#xff…

Filter的过滤链理解

一、Filter过滤链 web.xml配置了filter过滤器&#xff0c;在容器启动的时候执行了init()方法进行了初始化&#xff0c;然后在容器关闭的时候执行了destroy&#xff08;&#xff09;方法销毁过滤器&#xff0c;在每次服务器接受请求的时候每次都会先过一遍过滤器&#xff0c;如果…