最近没事干,在牛客网上刷题,刷到一个this指向的题。感觉有必要记录一下,顺便学习了。
先上题目:

执行下列选项的程序,输入后果不是Window对象的是()

// AsetTimeout(function(){    console.log(this);},1000);// Bfunction Star(){    console.log(this);}new Star();// Cvar o = {    sayHi:()=>{        console.log(this);    }}o.sayHi();// D(function(){    console.log(this);}());

答案是:B,上面来解释一下起因。

  1. 没有非凡场景,默认绑定,this就指向window
  2. 有关键字new,this就指向new进去的那个对象
  3. 看上去是obj在调用,然而实际上用了箭头函数,所以this还是指向window,起因是箭头函数没有本人的this,只能向外层寻找,因而还是指向this
  4. 没有非凡场景,默认绑定,this就指向window

总结:

  1. 谁调用thisthis就指向谁
  2. fn() 赤裸裸的,默认绑定,指向this,无论在哪里调用实际上是window.fn() window调用,指向window
  3. obj.fn() 隐式绑定,指向obj,obj在调用
  4. call()、apply()、bind 显式绑定,要指向谁就写在()外面
    5. new fn() new绑定,指向new创立的对象