ES6中的箭头函数

Posted 娃娃张开客辣

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ES6中的箭头函数相关的知识,希望对你有一定的参考价值。

箭头函数内部没有constructor方法,也没有prototype,所以不支持new操作。但是它对this的处理与一般的普通函数不一样。箭头函数的 this 始终指向函数定义时的 this,而非执行时。我们通过一个例子来理解:

var o = {
    x : 1,
    func : function() { console.log(this.x) },
    test : function() {
        setTimeout(function() {
            this.func();
        }, 100);
    }
};

o.test(); // TypeError : this.func is not a function

如果把代码改成这样

var o = {
    x : 1,
    func : function() { console.log(this.x) },
    test : function() {
        var _this = this;
        setTimeout(function() {
            _this.func(); 
        }, 100);
    }
};

o.test();

 

通过使用外部事先保存的this就行了。这里就可以利用到箭头函数了箭头函数的 this 始终指向函数定义时的 this,而非执行时。所以我们将上面的代码修改如下:

var o = {
    x : 1,
    func : function() { console.log(this.x) },
    test : function() {
        setTimeout(() => { this.func() }, 100);
    }
};

o.test();

这回this就指向o了。

以上是关于ES6中的箭头函数的主要内容,如果未能解决你的问题,请参考以下文章

ES6中的箭头函数

ES6 中的箭头函数中的“this”指的是啥?

ES6新特性2:箭头函数

ES6新特性2:箭头函数

ES6箭头函数中的this绑定问题

ES6箭头函数中的this绑定问题