浅析javascript中function 的 length 属性_基础知识
程序员文章站
2022-04-22 21:34:39
...
[1,2,3].length 可以得到 3, "123".length 也可以得到 3,这个略懂js的都知道。
function test(a,b,c) {}
test.length // 3
function test() { console.log( arguments );}
test.length // 0
function test() { console.log( arguments.length );}
test(1,2,3); // 输出 3
test(1,2,3,4); // 输出 4
但是 eval.length,RegExp.length,"".toString.length,1..toString.length 会得到什么呢?
分别得到 1,2,0,1,这些数字代表什么呢?
这个是群里很多新人朋友一直问的一个问题,其实函数的 length 得到的是形参个数。
我们来简单看个例子:
复制代码 代码如下:
function test(a,b,c) {}
test.length // 3
function test(a,b,c,d) {}
test.length // 4
是不是很简单,但是也有特殊的,如果函数内部是通过 arguments 调用参数,而没有实际定义参数的话,length 只会的得到 0。
复制代码 代码如下:
function test() { console.log( arguments );}
test.length // 0
这个函数确实可以传入参数,而且内部也调用了参数,但是 length 却无法得知传入的参数的个数。
只能在函数执行的时候通过 arguments.length 得到实参个数。
复制代码 代码如下:
function test() { console.log( arguments.length );}
test(1,2,3); // 输出 3
test(1,2,3,4); // 输出 4
所以函数的 length 属性只能得到他的形参个数,而无法得知实参个数。
上一篇: Win7 64位 php
下一篇: 有关字符串的提取
推荐阅读
-
JavaScript中length属性的使用方法
-
浅析JS中document对象的一些重要属性_javascript技巧
-
浅析JS中document对象的一些重要属性_javascript技巧
-
JavaScript中prototype为对象添加属性的误区介绍_基础知识
-
Javascript中 关于prototype属性实现继承的原理图_基础知识
-
JavaScript中Function()函数的使用教程_基础知识
-
javascript中的throttle和debounce浅析_基础知识
-
JavaScript中的Math.LOG2E属性使用详解_基础知识
-
Javascript学习笔记之数组的遍历和 length 属性_基础知识
-
浅析javascript中function 的 length 属性_基础知识