美文网首页
ES6箭头函数中的this指向

ES6箭头函数中的this指向

作者: 知名大学士 | 来源:发表于2020-03-13 22:56 被阅读0次

    箭头函数中的this指向与一般function定义的函数的this不同,普通function定义的函数的this指向的是 调用者且可以改变,而箭头函数的this的指向与调用者无关,在定义时确定且不可改变,

    1. 我们来看下面这个例子:

    function定义的函数:
    var x = 11;
    var obj = {
        x: 22,
        say: function() {
            console.log(this.x)
        }
    }
    obj.say();
    //console.log输出的是22
    

    一般的定义函数跟我们的理解是一样的,运行的时候决定this的指向,我们可以知道当运行obj.say()时候,obj是函数的调用者,所以this指向的是obj对象。

    箭头函数:
    var x = 11;
    var obj = {
      x: 22,
      say: () => {
        console.log(this.x);
      }
    }
    obj.say();
    //输出的值为11
    

    这样就非常奇怪了如果按照之前function定义应该输出的是22,而此时输出了11,那么如何解释ES6中箭头函数中的this是定义时的绑定呢?

    2. 如何确定箭头函数this的指向谁?

    一句话:扒掉外层的箭头函数,此时的this 指向谁,那么箭头函数 this 就永远指向谁。
    我们还是以这段代码为例,此时函数的调用者为obj,我们拔掉这层皮,此时this实际指向Window,也就是this.x实际为Window.x,也就是我们所定义的var x = 11;中的x,所以输出结果为11而不是22

    var x = 11;
    var obj = {
      x: 22,
      say: () => {
        console.log(this.x);
      }
    }
    obj.say();
    //输出的值为11
    

    相关文章

      网友评论

          本文标题:ES6箭头函数中的this指向

          本文链接:https://www.haomeiwen.com/subject/jocushtx.html