JavaScript arguments callee caller 学习笔记

arguments


假设定义了一个函数a,函数a的实际参数只有一个x,如果调用这个函数a的时候传入两个实参,第一个实参可以根据参数名x来获得,也可以通过类数组对象arguments[0]来获取,而第二个实参就只能通过arguments[1]来得到,跟js真正的数组一样,arguments对象也包含一个length属性,用来记录和标识该对象所包含的元素的个数,所以,如果调用函数a传入了两个参数,length的值就为2,如果调用函数时没有传入形参,arguments对象为null;


//需要三个形参的函数
function testArgs(a , b ,c ){
    //判断调用函数时传入的形参个数是否正确
    if(arguments.length != 3)
        //如果传入形参个数不等于3个,抛出异常信息
        throw new Error("调用函数错误,参数个数不一致");
    //执行其他逻辑
    return a + b + c;
}

在非严格模式下,如果一个函数包含若干个形参,实参对象的数组元素是函数形参所对应实参的别名,实参对象中以数字索引,如果通过实参的名字来修改实参的值,arguments对象中对应的值也会发生改变。


//上述文字示例
function demo2(a){
    console.log("修改前参数a的值:" + a);
    a = 100;
    console.log("修改后arguments对应的值:" + arguments[0]);
}
//调用函数
demo2(10);

arguments对象使用范例:


//查找传入函数的数字中最大的值
//"/*...*/"表示可以接受任意个数的参数
function findMaxNumber(/*...*/){
    //定义一个无限值
    var max = Number.NEGATIVE_INFINITY;
    //遍历arguments对象,查询并记录最大值;
    for(var i = 0; len = arguments.length; i < len; i ++){
        //判断当前值是否大于最大值Max变量
        if(arguments[i] > max)
            //将值存入最大值变量中
            max = arguments[i];
    }
    //遍历完对象,返回最大值
        return max;
}
//调用函数
findMaxNumber(1,2,3,4,5,6,7,8,9,10); ⇒ 10;

arguments对象中的callee属性和caller属性


实参对象arguments除了数组元素之外,该对象还定义了callee和caller属性。在ECMAScript5的严格模式下,对实参对象中的这两个属性操作都会产生一个类型错误:

Uncaught TypeError: Cannot read property 'length' of undefined

而在非严格模式下,ECMAScript标准规范规定callee属性指代当前正在执行的函数。caller是非标准的,但是绝大多数的浏览器都实现了这个属性,它指代当前执行函数的函数,callee通常用于匿名函数调用。


使用callee属性实现递归(函数自己调用自己)

//将匿名函数赋值给一个变量
var factorial = function(num){
    if(num <= 1)
        return 1;
    //递归调用自身函数;
    return num * arguments.callee(num - 1);
}

//调用函数
var test = factorial(10);⇒ 1*2*3*4*5*6*7*8*9*10=3628800

caller使用示例

//定义一个函数,返回调用函数的函数
function callerFn() { 
    //函数被直接执行时callerFn.caller为空
    if (callerFn.caller) { 
            //返回执行当前函数的函数的toString方法
            return callerFn.caller.toString(); 
        } else { 
            alert("函数直接执行"); 
    } 
} 
//调用函数
function handleCaller() { 
    callerFn(); 
} 
handleCaller(); 
    callerFn(); 
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值