• 技术文章 >web前端 >js教程

    js中call、apply、bind的区别

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

    js中call、apply、bind的区别

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

    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中文网其它相关文章!

    声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
    专题推荐:JavaScript call apply bind
    上一篇:Vue中Computed和Watch的用法及区别 下一篇:node-sass安装报错的解决办法
    大前端线上培训班

    相关文章推荐

    • DEDECMS幻灯片中JavaScript怎么应用• JavaScript的三大组成部分• javascript原型链污染攻击• JavaScript中常用的20个字符串方法(收藏)

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网