源码
Function.prototype.bind = Function.prototype.bind || function(context) {
var that = this;
return function() {
return that.apply(context, arguments); // 这里为什么要用 that.apply, 作用是什么?
}
}
很疑惑,为什么要用that.apply, 仅仅是为了让bind返回一个func而不是一个结果?
源码
Function.prototype.bind = Function.prototype.bind || function(context) {
var that = this;
return function() {
return that.apply(context, arguments); // 这里为什么要用 that.apply, 作用是什么?
}
}
很疑惑,为什么要用that.apply, 仅仅是为了让bind返回一个func而不是一个结果?
that.apply(context,arguments)返回的是一个结果,会调用that函数,这里主要是改变上下文的,用that.call(context, ...arguments)也可以
13 回答12.9k 阅读
7 回答2.1k 阅读
3 回答1.3k 阅读✓ 已解决
2 回答1.3k 阅读✓ 已解决
6 回答1.2k 阅读✓ 已解决
6 回答1.1k 阅读
3 回答1.3k 阅读✓ 已解决
返回的是一个匿名函数,用that代替this,是将当前上下文对象传入这个返回 匿名函数。如果用this的话。就是一个新的上下文。