function add (a, b) {
return a + b;
}
var make_lazy = function (fn) {
return fn.bind.apply(fn, arguments); //??? 不理解这一行
};
var lazy_value = make_lazy(add, 2, 3);
lazy_value() // => 5
apply() call() bind()的基础用法,我明白。但是bind.apply()这样连用,就有点含混了。
大侠可否将那一行拆解开,讲解下,具体怎样一步步起作用的?
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
apply/call/bind都为函数对象的方法,
apply/call用于调用执行指定的函数,第1个参数执行函数执行时的上下文
bind方法为指定的函数对象创建一个新的函数,传入的第1个参数这个新函数执行时的上下文
bind方法可以理解为对apply方法的封装调用
1.fn.bind获取传入的函数对象的bind方法,和
Function.prototype.bind等价2.调用apply方法,将fn作为bind方法调用时的函数对象(也即bind方法调用时的this对象)
3.bind方法从第2个参数开始可以传入多个参数,所以使用make_lazy方法调用时传入全部参数arguments做为apply方法的第2个参数,arguments中的第1个参数为fn
1替代思考
照着调用替换一下参数可得
2回忆比较
一般
借用方法的做法我们常见的有Array.prototype.slice.apply(arguments)如
3分析
可以这个题目的写法似乎是
借用自己的方法add.bind.apply是为add.bind指定另外一个this对象,而这个要被指定的对象恰好又是自己add。bind的目的是构造一个新的方法,且有确定的this对象。所以
make_lazy最终目的是bind出来一个新的方法。然后可以调用新的方法就可以获得结果,就是后面的
lazy_value()4猜测
猜测这么做的目的(胡乱猜测的)
1.lazy求值
2.让add方法无状态
其实是偷懒的写法
return fn.bind.apply(fn, arguments);
有了es6之后,这一行可以换成:
return fn.bind(...arguments);
由于arguments中的第一个参数就是fn,那么说这两行等价应该也没什么问题。
具体的执行过程如下: