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...