浅析javascript中function 的 length 属性
2018-10-12 14:06
369 查看
[1,2,3].length 可以得到 3, "123".length 也可以得到 3,这个略懂js的都知道。
但是 eval.length,RegExp.length,"".toString.length,1..toString.length 会得到什么呢?
分别得到 1,2,0,1,这些数字代表什么呢?
这个是群里很多新人朋友一直问的一个问题,其实函数的 length 得到的是形参个数。
我们来简单看个例子:
function test(a,b,c) {}
test.length // 3function 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 属性只能得到他的形参个数,而无法得知实参个数。
您可能感兴趣的文章:
相关文章推荐
- 浅析javascript中function 的 length 属性
- length 属性 (Function) (JavaScript)
- javascript Function对象的length属性及js函数的预执行
- JavaScript function 的 length 属性
- JavaScript function 的 length 属性使用介绍
- JavaScript function 的 length 属性使用介绍
- javascript巧用数组length属性清空和截短数组
- Javascript 中函数的 length 属性
- Javascript自执行匿名函数(function() { })()的原理浅析
- Javascript将字符串日期格式化为yyyy-mm-dd的方法 js number 类型 没有length 属性 string类型才有
- 【JavaScript】浅析JavaScript对象如何添加属性和方法
- javascript textarea MaxLength 属性的实现
- 浅析JavaScript之Function类型
- 全面理解Javascript中Function对象的属性和方法
- JavaScript Length 属性的总结
- 浅析JavaScript访问对象属性和方法及区别
- Javascript中函数名.length属性用法分析(对比arguments.length)
- javascript:函数的apply,call方法和length属性
- JavaScript的Function与Object浅析
- 浅析 JavaScript 中的 Function.prototype.bind() 方法