函数fun.length 以及arguments.length问题

先马克下,今早研究了下 下次详写
1.f.length 和 arguments.length的区别

2.使用bind后 函数的 length

3.Function 构造函数的length为1,这点至今没弄明白

4.对于ES6+ 含默认参数的 函数length

 

 

1.funname.length 指的是函数的形参个数,arguments.length指的是实参的个数。

例如:  function fun(a,b,c){
                   console.log("测试函数的length");

                   console.log(arguments.length)
             }
             fun(1);//测试函数的length   1
             console.log(fun.length) //3

函数fun.length 为 3 .

2.使用bind后函数的length.

bind后形成了一个新函数,新函数的length为 原函数的length-bind传入的参数。

如下图: a处规则按上方

               b.f1函数内的arguments。length为 bind绑定的参数+f1传入的参数  2+2 =4

               c.f1.length为 原函数应传入的参数个数- bind绑定的参数  3-2 =1
  function fun(a,b,c){
                   console.log("测试函数的length")
                   console.log(arguments.length)
   }
  fun(1);                  //   a.测试函数的length  1
var f1 = fun.bind(null,2,3);
f1(3,4)                     // b.测试函数的length   4
console.log(f1.length)                          // c.1

 

 

4.(function(a,b,c=3){}).length    //2

(function(a,b=3,c,d){}).length   //1

函数length 为 第一个默认参数之前 形参个数

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值