普通函数中的this:

1. this总是代表它的直接调用者,  例如 obj.func , 那么func中的this就是obj

2.在默认情况,没找到直接调用者,  则this指的是 window

3.在严格模式下,没有直接调用者的函数中的this是 undefined

4.使用call,apply, bind(ES5新增)绑定的, this指的是 绑定的对象

箭头函数中的this

1. 默认指向在定义时作用域, 它所处的对象,而不是执行时的对象, 定义它的时候,可能环境是window(即继承父级的this);

下面通过一些例子来研究一下 this的一些使用场景

ES6中箭头函数与普通函数this的区别

原因:箭头函数不会自动绑定局部变量,如this,arguments,super(ES6),new.target(ES6)等

所以箭头函数没有它自己的this值,箭头函数内的this值继承自外围作用域。在箭头函数中调用 this 时,仅仅是简单的沿着作用域链向上寻找,找到最近的一个 this 拿来使用


相关文章:

  • 2021-08-29
  • 2021-05-25
  • 2022-12-23
  • 2021-11-18
猜你喜欢
  • 2022-12-23
  • 2022-12-23
  • 2021-05-23
  • 2021-11-14
  • 2021-05-15
相关资源
相似解决方案