js 函数内部的特殊对象

一. 了解 arguments

arguments 只有在以 function 定义的函数中才会出现,其代表该函数内的所有参数,其本身是一个类数组对象,其运用也很简单,今天我们来学习其下的两个参数,callee 和 caller

二. callee

arguments.callee 指向 arguments 对象所在的函数。

我们写一个简单的递归阶乘:

 let fun = function(n){
        if(n === 1) return 1;
        return n*fun(n-1)
    }
    console.log(fun(5))

通过 callee 参数是实现

    let fun = function(n){
        if(n === 1) return 1;
        return n*arguments.callee(n-1)
    }

这样做可以很好的让函数逻辑和函数名解耦,无论该函数如何改名字,都不需要去重改内部递归函数的名字

三. caller

该属性引用的是调用当前函数的函数

    function outer(){
        inner();
    }

    function inner(){
        console.log(inner.caller); // outer 的代码
    }
    outer();

该内部函数名同样可以解耦,用 arguments 来表示

    function outer(){
        inner();
    }

    function inner(){
        console.log(arguments.callee.caller);
    }
    outer();

 四. new.target 

ES 中的函数始终可以作为构造函数实例化一个新对象, 也可以作为普通函数被调用,ES6 为了检测函数是通过 new 调用还是正常调用,特地增加了 new.target  对象来标识,如下所示

function fun (){
    console.log(new.target)
}
fun() // undefined
new fun() // fun 函数

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员-石头山

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值