call、apply、bind方法的共同点和区别

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 则是立即调用 。
*/

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容