首先明确:this指向JavaScript实例,因此只有在函数调用时才可以确定下来,而在函数声明时是无法确定的!
一、全局中的this
无论是否在严格模式下,在全局执行环境中(在任何函数体外部)this 都指向全局对象window。
二、常规函数中的this
this只有在函数被调用时才能确定下来,this指向调用函数的对象;
this最靠近的引用优先级最高;
可以用call()或bind()指定this;
构造函数的this指向new返回的对象;
DOM元素的监听处理函数的this指向监听器所在的DOM元素;window.setTimeout()和window.setInterval()的函数中的this默认是window对象。
三、箭头函数的this
箭头函数不会创建自己的this,它只会从自己的作用域链的上一层继承this;箭头函数不能用call()或bind()指定this。
补充:
1.当this碰到return时,如果返回值return的是一个对象,那么this指向的就是那个返回的对象,如果返回值不是一个对象那么this还是指向函数的实例。
还有一点就是虽然null也是对象,但是在这里this还是指向那个函数的实例,因为null比较特殊。
2.全局作用域中函数的this:
es5,非严格模式this指向window,严格模式this指向undefined;es6箭头函数的this都指向window