JavaScript中的caller和callee

caller 返回一个调用当前函数的引用(caller就是给你打电话的人,谁给你打电话,谁就调用了你),在浏览器中,如果调用当前函数的是window,则返回null;

function fn() {
    console.log(fn.caller);
}
fn();   // window调用了fn,返回null;
function fn() {
    console.log(fn.caller);
}
function fun() {
    fn();
}
fun();  // 此时fun调用了fn,返回fun,即 function fun() {fn()};

callee 是arguments的一个属性,它返回正在执行的当前函数本身的引用;

注意:
1. callee只有在函数执行时才有效;
2. 它有一个length属性,可以表示形参的个数;

function fn() {
    console.log(arguments.callee);
};
fn();   //返回 function fn() {console.log(arguments.callee);}

callee 的用途:

1. 递归

下面一个经典的阶乘(递归)

function fn(num) {
    if(num <= 1) {
        return 1;
    }else {
        return num * fn(num - 1);
    }
}
fn(5);  //5*4*3*2*1=120

为避免函数名修改导致函数内部报错,可以改成一下写法

function fn(num) {
    if(num <= 1) {
        return 1;
    }else {
        return num * arguments.callee(num - 1);
    }
}
fn(5);  //5*4*3*2*1=120

2. length 的用法

function fn(a, b, c) {
    // 实参长度为 2
    console.log(arguments.length);
    // 形参长度为 3
    console.log(arguments.callee.length);
}
fn(0, 1);

猜你喜欢

转载自blog.csdn.net/a790012863/article/details/80660671