函数中的 Arguments 对象详解
每个函数都会有一个 Arguments 对象实例 arguments,它引用着函数的实参,可以用数组下标的方式”[]”引用 arguments 的元素。 arguments.length
为函数实参个数, arguments.callee
引用函数自身。
Arguments 对象介绍
Arguments 对象是一个伪数组对象,它有 length 属性,可以 arguments[i]来访问对象中的元素,但它不能用数组的一些方法,例如 push,pop,slice 等。
Arguments 的 length 属性
Arguments 的 length 属性,表示 function 函数实际所传参数的个数。函数名点 length 可以获取函数期望的传参个数。
function argTest(a,b,c){
var t = arguments.length; //实际传参个数
var e = argTest.length; //期望传参个数
console.log(t);
console.log(e);
}
argTest(11,12); //t=2,e=3
argTest(11,12,13); //t=3,e=3
argTest(11,12,13,14); //t=4,e=3
Arguments 的参数访问
Arguments 对象的参数访问可以用 arguments[i]来访问函数所传的参数。
function argTest(a,b,c){
var arg = [];
for(var i=0;i<arguments.length;i++){
arg.push(arguments[i]);
}
console.log(arg);
}
argTest(11,12); //[11, 12]
argTest(11,12,13); //[11, 12, 13]
argTest(11,12,13,14); //[11, 12, 13, 14]
Arguments 的 callee 调用
Arguments 的 callee 属性可以调用函数本身,当函数正在执行时才可调用,可以实现方法的递归调用。
function argTest(a,b,c){
var e = arguments.callee.toString();
console.log(e);
}
argTest(); //打印出函数本身
Function 对象 caller 属性
Function 对象的 caller 属性可以指向当前函数的调用者,当调用者函数正在执行时才可调用,
function callerTest(){
if(callerTest.caller){
var caller = callerTest.caller.toString();
console.log(caller);
}else{
console.log("no caller")
}
}
function handler(){
callerTest();
}
function handlerToHandler(){
handler();
}
callerTest(); //no caller
handler(); //返回调用者 handler 函数
handlerToHandler(); //返回调用者 handler 函数
Arguments 的作用
方法重载
方法重载是指在一个类中定义多个同名的方法,但要求每个方法具有不同的参数的类型或参数的个数。
Javascript 并没有重载函数的功能,但是 Arguments 对象能够模拟重载。
//普通方法实现方法重载
function test(a,b,c){
if(a && b && c){
console.log(a + b + c);
}else if(a && b){
console.log(a + b);
}else{
console.log(a);
}
}
test(); //undefined
test(11,12); //23
test(11,12,13) //36
//Arguments 对象实现方法重载
function test(){
var sum = 0;
for(var i=0;i<arguments.length;i++){
sum += arguments[i];
}
console.log(sum);
}
test(); //0
test(11,12); //23
test(11,12,13); //36
//ES6 实现方法重载
function test(...nums){
var sum = 0;
for(var i=0;i<nums.length;i++){
sum += nums[i];
}
console.log(sum);
}
test(); //0
test(11,12); //23
test(11,12,13); //36
递归调用
这样的好处就是可以实现匿名函数的递归调用。
//实现一个阶乘函数
function factorial(n){
if(n == 1){
return 1;
}else{
n * arguments.callee(n-1);
}
}
factorial(1); //1
factorial(5); //120
不定参问题
比如说,我想判断你传给我的一些数字的大小,取出最大的那个
function max(){
var maxNum = Number.NEGATIVE_INFINITY;;
for(var i=0;i<arguments.length;i++){
if(arguments[i]> maxNum){
maxNum = arguments[i];
}
}
return maxNum;
}
max(1,2,3,11,4,10); //11
max(2,-10,22,11); //22
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
上一篇: HTML5 之 API 总结
下一篇: 彻底找到 Tomcat 启动速度慢的元凶
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论