var obj = {
x: 81,
};
var foo = {
getX: function() {
return this.x;
}
}
console.log(foo.getX.bind(obj)()); //81 注意:bind方法的返回值是函数
console.log(foo.getX.call(obj)); //81
console.log(foo.getX.apply(obj)); //81
/*
apply 、 call 、bind 三者都是用来改变函数的this对象的指向的;
•apply 、 call 、bind 三者第一个参数都是this要指向的对象,也就是想指定的上下文;
•apply 、 call 、bind 三者都可以利用后续参数传参;
•bind 是返回对应函数,便于稍后调用;apply 、call 则是立即调用 。
*/
call、apply、bind方法的共同点和区别
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
推荐阅读更多精彩内容
- 在js中,所有的函数再被调用的时候都会默认传入两个参数,一个是this,还有一个是arguments。在默认情况下...
- call/apply/bind方法的来源call,apply和bind方法都是继承自Function.protot...
- call、apply、bind的作用是改变函数运行时this的指向,所以先说清楚this。 以下是函数的调用方法:...
- call() 、 apply() 、bind()方法的作用和区别! 从一开始,我是在书上看到关于bind()、ca...