箭头函数的this指向哪里

箭头函数的this指向哪里

经常可以使用看到箭头函数的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);
        };
    }
};

个人博客地址:大家可以看看

发布了49 篇原创文章 · 获赞 51 · 访问量 7364

猜你喜欢

转载自blog.csdn.net/qq_41108972/article/details/104963999