JavaScript中鲜为人知的Arguments

今天偶有所感,随及写了一个测试数据的生成工具,主要是因为在长期的开发过程中,需要给数据库添加合适的测试数据,供系统运行,在开发过程中,偶遇Arguments,说来惭愧,工作近乎一年,我竟然未曾相识,闲话少扯,撸码。

Arguments:可变长达的实参列表,实参对象(官方解释,来源权威指南P174)。

详解:当调用函数时传入的实参个数大于函数定义中的形参个数时,超过接收范围的实参将无法被形参接收,恰在此时,Arguments便应运而生,挺身而出。

举个栗子:

    function   sum(){
            //公众号关注:挨踢小子
            var sum=0;  
            for(var i=0;i<arguments.length;i++){

                sum+=arguments[i];

            } 
                return sum
        }
     console.log(sum(1,2,3,4));  //10

也就是说,当我们不定义形参时,同样可以调用定义函数,在函数内部通过arguments按顺序调用即可,类似数组。

arguments[0]
arguments[1]
arguments[2]

其参数也可以被设置为:

arguments[1] = 'Aiti';

注意arguments对象不是一个 Array ,它类似于Array,除了length属性和索引元素之外没有任何Array属性。当然可以将其转化为一个真正的数组。

方法一:

 function fun(){
         //公众号关注:挨踢小子
         var arr =[]; 
         for(var i = 0 ; i<arguments.length;i++){
             arr.push(arguments[i]);
            }
              return arr;
       }
       console.log(fun(1,2,3,4)); 

方法二:

 function fun(){ 
              //公众号关注:挨踢小子
               return [].slice.call(arguments);
            }
         console.log(fun(1,2,3,4)); 

方法三:

function fun(){ 
         //公众号关注:挨踢小子
         return Array.from(arguments);
   }
     console.log(fun(1,2,3,4));               

 

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值