将函数的实际参数转换成数组的方法

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/running_shuai/article/details/82347000

将函数的实际参数转换成数组的方法

    方法一:
     var args = Array.prototype.slice.call(arguments);
    方法二:
      var args = [].slice.call(arguments, 0);
    方法三:
    var args = []; 
    for (var i = 1; i < arguments.length; i++) { 
           args.push(arguments[i]);
    }
    最后,附个转成数组的通用函数
    var toArray = function(s){
        try{
            return Array.prototype.slice.call(s);
        } catch(e){
            var arr = [];
            for(var i = 0,len = s.length; i < len; i++){
                //arr.push(s[i]);
                   arr[i] = s[i];  //据说这样比push快
            }
             return arr;
        }
    }

理解

1、基础

1)slice() 方法可从已有的数组中返回选定的元素。
    start:必需。规定从何处开始选取。如果是负数,那么它规定从数组尾部开始算起的位置。  
           也就是说,-1 指最后一个元素,-2 指倒数第二个元素,以此类推。
    end: 可选。规定从何处结束选取。该参数是数组片断结束处的数组下标。  
        如果没有指定该参数,那么切分的数组包含从 start 到数组结束的所有元素。  
        如果这个参数是负数,那么它规定的是从数组尾部开始算起的元素。

        返回一个新的数组,包含从 startend (不包括该元素)的    
        arrayObject 中的元素。该方法并不会修改数组,而是返回一个子数组。

2call()和apply()方法都是在特定的作用域中调用函数,实际上等于设置函数体内this对象的值。apply和call方法的第一个参数都是特定的作用域第二个参数不同,apply第二个参数可以是Array的实例,也可以是arguments对象。call方法需要逐个列出需要传递的参数。

3)arguments对象指数与数组类似(它并不是Array的实例),但是可以使用方括号语法访问每一个元素,使用length来确定传递进来多少个参数。

4)Array.prototype.slice.call()可以理解为:改变数组的slice方法的作用域,在特定作用域中去调用slice方法,call()方法的第二个参数表示传递给slice的参数即截取数组的起始位置。

猜你喜欢

转载自blog.csdn.net/running_shuai/article/details/82347000