js中call、apply、bind的区别


本文摘自PHP中文网,作者angryTom,侵删。

在 javascript 中,call、apply、bind 都是为了改变某个函数运行时的上下文(context)而存在的,换句话说,就是为了改变函数体内部 this 的指向。

js中call、apply、bind的区别

call、apply、bind三者的区别,可以通过下面这个例子来看。

1

2

3

4

5

6

7

8

9

10

11

12

13

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的区别的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

js如何使用索引访问数组对象中的元素

javascript之undefined与null的区别(详解)

jquery中prop什么意思

javascript使用什么标签实现

怎么将javascript对象转换为json字符串

如何选择web前端模板引擎(推荐)

javascript用什么方法触发按钮的被点击事件

详解javascript的空值合并运算符(??)

举例说明js调用php和php调用js的方法

javascript怎么将字符串转小写

更多相关阅读请进入《javascript》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...