ES6箭头函数中的this指向

2020-03-13  本文已影响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
上一篇下一篇

猜你喜欢

热点阅读