递归 arguments.callee 正在执行的函数的指针属性

function factorial(num){
    if(num <= 1){
        return 1;
    }else{
        return num * factorial(num - 1);
    }
}
console.log(factorial(5));  
一开始的常规写法,但是有个问题是内部调用自身是使用函数名字,如果在将factorial赋值到一个变量之后,尽管还是调用原factorial函数,但不是期望的调用函数自身的写法了

此时假如用一个变量赋值当期函数,再把递归函数变为null,后面再用赋值函数时就找不到这个值了

function factorial(num){
    if(num <= 1){
        return 1;
    }else{
        return num * factorial(num - 1);
    }
}
var another = factorial;
console.log('another = ',another);
factorial = null;
console.log('factorial = ',factorial);
console.log(another(5));     

up-27784a196200402fbce4929ee3fb108f7c4.png

缺点:
a.严格模式下,不能通过脚本访问arguments.callee,访问这个属性会导致错误;
b.arguments是庞大且变化的,每次访问需要消耗大量性能;
2.命名函数表达式

var factorial = (function f(num){
    if(num <= 1){
        return 1;
    }else{
        return num * f(num - 1);
    }
});
var another = factorial;
factorial = null;
console.log(another(5));        //  120

这种方式在严格模式和非严格模式下都行得通

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 JavaScript 中,`arguments.callee` 用于引用当前正在执行函数。然而,由于使用 `arguments.callee` 会导致性能问题,现代 JavaScript 已经不再支持该属性。因此,我们应该使用命名函数表达式或箭头函数来替代 `arguments.callee`。 例如,一个使用 `arguments.callee` 的函数可以被重写为命名函数表达式: ```javascript // 使用 arguments.callee 实现函数 var factorial = function(n) { if (n <= 1) { return 1; } else { return n * arguments.callee(n - 1); } }; // 使用命名函数表达式替代 arguments.callee var factorial = function factorial(n) { if (n <= 1) { return 1; } else { return n * factorial(n - 1); } }; ``` 在这个例子中,我们将函数名 `factorial` 显式地赋值给了函数表达式,并在函数体内使用它来归调用自身。 另外,箭头函数没有自己的 `this` 和 `arguments`,因此也不需要使用 `arguments.callee`。我们可以使用命名函数表达式来替代箭头函数归调用。例如: ```javascript // 使用箭头函数实现函数(错误的方式) const factorial = (n) => { if (n <= 1) { return 1; } else { return n * factorial(n - 1); // TypeError: factorial is not a function } }; // 使用命名函数表达式替代箭头函数 const factorial = function fac(n) { if (n <= 1) { return 1; } else { return n * fac(n - 1); } }; ``` 在这个例子中,我们使用了命名函数表达式 `function fac(n)` 来替代箭头函数,并在函数体内使用 `fac` 来归调用自身。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值