ES6 箭头函数使用(this作用域总结)

前言

ES6中添加了箭头函数,可以更方便绑定this作用域了 O.o
至于使用,我觉得一个实例就够了 我不信看完还有不会用的

实例代码

const x = 1;
this.x = 4; // this  default {}
global.x = 2;

let fun1 = () => {
    console.log('fun1', this.x); // 4 this => this
};


const obj = {
    x: 3,
    fun: function () {
        console.log('fun', this.x); // 3 this => obj
        let fun2 = () => {
            console.log('fun2', this.x); // 3 this => fun => obj
        };
        let fun3 = function () {
            console.log('fun3', this.x); // 2 this => global
        };
        let fun4 = fun1;
        let fun6 = fun3.bind(this);
        fun1();
        fun2();
        fun3();
        fun4(); // 4 this => this
        fun6(); // 3 this => obj
    }
};
obj.fun();
console.log(this); // { x: 4 }
console.log(this.x); // 4 this => this
posted @ 2020-06-05 10:50  落叶&不随风  阅读(334)  评论(0编辑  收藏  举报