call
call 的基本功能:
call() 方法使用一个指定的 this 值和单独给出的一个或多个参数来调用一个函数。
原型
不涉及原型链的转移,不用管
this
本质上,call 就是 this 的转移
返回值
apply
apply 和 call 区别,只有一些入参和性能上的区别。直接上代码:
Function.prototype.myApply = function(context = window, args) {
context.fn = this; // 先将fn挂在context上,
var res = context.fn(…args); // 然后通过context调用fn,使得fn中的this指向指到context上
delete context.fn; // 最后删除掉context上的fn
return res; // 返回原函数的返回值
};
bind
bind 有点不一样,它会返回一个绑定了 this 的函数。
bind()方法创建一个新的函数,在 bind()被调用时,这个新函数的 this 被 bind 的第一个参数指定,其余的参数将作为新函数的参数供调用时使用。
Function.prototype.myBind = function(context, …args) {
var fn = this;
var newFn = function(…restArgs) {
// 使用call去调用fn,因为bind可能会bind一部分参数,所以把restArgs也传进去
return fn.call(context, …args, …restArgs);
};
return newFn;
};
上面的函数基本上覆盖了大部分场景,但是不能支持new调用——
绑定函数自动适应于使用 new 操作符去构造一个由目标函数创建的新实例。当一个绑定函数是用来构建一个值的,原来提供的 this 就会被忽略。不过提供的参数列表仍然会插入到构造函数调用时的参数列表之前。