我是靠谱客的博主 鲤鱼早晨,最近开发中收集的这篇文章主要介绍函数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 为 第一个默认参数之前 形参个数

最后

以上就是鲤鱼早晨为你收集整理的函数fun.length 以及arguments.length问题的全部内容,希望文章能够帮你解决函数fun.length 以及arguments.length问题所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(55)

评论列表共有 0 条评论

立即
投稿
返回
顶部