作者:最最时尚搭配攻略_ | 来源:互联网 | 2020-09-05 03:35
js中call、apply、bind的区别有:1、bind是返回对应的函数,便于稍后调用;2、apply,call是立即调用;3、在ES6的箭头函数下,call和apply将失效。
在 Javascript 中,call、apply、bind 都是为了改变某个函数运行时的上下文(context)而存在的,换句话说,就是为了改变函数体内部 this 的指向。
var obj = {
x: 81,
};
var foo = {
getX: function() {
return this.x;
}
}
console.log(foo.getX.bind(obj)()); //81
console.log(foo.getX.call(obj)); //81
console.log(foo.getX.apply(obj)); //81
三个输出的都是81,但是注意看使用 bind() 方法的,他后面多了对括号。
也就是说,区别是,当你希望改变上下文环境之后并非立即执行,而是回调执行的时候,使用 bind() 方法。而 apply/call 则会立即执行函数。
总结一下:
apply 、 call 、bind 三者都是用来改变函数的this对象的指向的;
apply 、 call 、bind 三者第一个参数都是this要指向的对象,也就是想指定的上下文;
apply 、 call 、bind 三者都可以利用后续参数传参;
bind 是返回对应函数,便于稍后调用;
apply 、call 则是立即调用 。
本文来自 js教程 栏目,欢迎学习!
以上就是js中call、apply、bind的区别的详细内容,更多请关注 第一PHP社区 其它相关文章!