箭头函数的this指向哪里


箭头函数的this指向哪里

箭头函数不同于传统JavaScript中的函数,箭头函数并没有属于自己的this,它的所谓的this是捕获其所在上下文的 this 值,作为自己的 this 值,并且由于没有属于自己的this,而箭头函数是不会被new调用的,这个所谓的this也不会被改变.

我们可以用Babel理解一下箭头函数:

// ES6
const obj = {
    getArrow() {
        return () => {
            console.log(this === obj);
        };
    }
} 

转化后

// ES5,由 Babel 转译
var obj = {
    getArrow: function getArrow() {
        var _this = this;
        return function () {
            console.log(_this === obj);
        };
    }
};

文章作者: 曹豆芽
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 曹豆芽 !
 上一篇
对MVVM的理解? 对MVVM的理解?
对MVVM的理解?MVVM是什么?MVVM 模式,顾名思义即 Model-View-ViewModel 模式。它萌芽于2005年微软推出的基于 Windows 的用户界面框架 WPF ,前端最早的 MVVM 框架 knockout 在201
2020-03-20
下一篇 
CSS相关布局小知识 CSS相关布局小知识
CSS相关布局小知识左边定宽,右边自适应方案:float + margin,float + calc/* 方案1 */ .left { width: 120px; float: left; } .right { margin-
2020-03-18
  目录