场景:

var mut = function(){
    console.log(arguments)
}

// 第一种情况
var factory = function(fn){
    return function(){
        return fn(arguments)
    }
}

// 第二种情况
var factory = function(fn){
    return function(){
        return fn.apply(this, arguments)
    }
}


// 运行
var fa = factory(mut)
fa(1,2,3,4,5,6)

一。第一种情况:factory 中直接返回 fn 的 arguments

则在 mut 中打印出来的是 

解释:将 factory 中的 arguments 传入 fn 的argumeng中,所以这里的 arguments 是fn中的第一个元素

 

二。第二种情况:使用 apply 输入 arguments

则在 mut 打印出来的是 

解释:因为 apply 后面输入的是一个数组,所以传进去的也是一个数组不是一个 arguments

 

三。总结

mut 函数没有用到 this 的属性,所以也没有借用 factory 对象函数的可能,所以这里 apply 的用处就是把 arguments 弄成一个数组而不是对象传进去

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐