js 中this到底指向哪里?

Posted yangkun90

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js 中this到底指向哪里?相关的知识,希望对你有一定的参考价值。

其实js的this指向很简单。我们记住下面3种情况。

  1. this 指向的是浏览器中的window.代码如下:
    function fn(){
      this.name=‘yangkun‘;
      this.age=28;    
    }

    当我们执行fn()的时候,这个普通函数中的this指向到底是什么?答案就是指向的是浏览器中的window.(这里说明,这里实在浏览器下,如果是node环境不是)。

  2. 如果这个时候我们对上面的函数进行进一步操作:
    function fn(){
      this.name=‘yangkun‘;
      this.age=28;    
    }
    var f=new fn;
    console.log(f.name);
    //yangkun //这个时候貌似this指向的是实例中的name值。

    fn类(这里使用了构造函数new方式生成,这个时候函数fn可以看做是一个类),生成了一个实例f ,其中f的name,就是类分配给实例f的私有属性值,这个时候this指向的就是f实例。

  3. 使用call,apply,bind:这些方法可以直接修改this的指向到任意的对象甚至变量。

 

综上所描述:1规律:如果在点语法前有谁,这个this就是谁。2 如果使用call,apply,bind这些方法可以改变this的指向性。

以上是关于js 中this到底指向哪里?的主要内容,如果未能解决你的问题,请参考以下文章

JS中this到底指向谁?

JS中this到底指向谁?

JS中this到底指向谁?

JavaScript-改变this指向

this 知多少

this的五种指法