Jq this的指向问题

JavaScript 有一套完全不同于其它语言的对 this 的处理机制。 在五种不同的情况下 ,this 指向的各不相同。
1.全局范围内 this
2. 这样也是全局 test.foo();
3.方法调用,指向test test.foo();
4. new foo(); 指向新创建的函数
5.apply,call 函数内的 this 将会被 显式设置为函数调用的第一个参数。

this指向核心的一句 :哪个对象调用函数,函数里面的this指向哪个对象。

1.第一种情况,这个this指向的是全局对象,因为它是在全局调用的
 var name="abc";
   function test()
  {
      console.log(name);//abc
 }
test();
2 new这个实例会改变this的指向,因为用new后开辟一个新的内存,然后this会指向新开辟的内存

    var name="小兰";
    function test(name)
     {
         this.name=name
         console.log(this.name);//小黑
      }
   var windownew=new test("小黑")();




下面两例子可以很明显的对比出来,谁调用的函数this就指向谁,第一个例子很明显是eat这个调用的,所以其this就指向eat的作用域,第二个例子很明显是全局调用,所以this指向全局变量
   var name="小白";
    function Animal(name,age){
                this.name=name;
                this.age=age;
            }
            //原型中添加方法
            Animal.prototype.eat={ 
              name:"小黄",
              methodone:function(){
                console.log(this.name)//小黄
              },
              methodtwo:function(){
                console.log(this.name)//小白
              }                      
            }; 
            var dog=new Animal("小苏",20);
        var dogtwo=dog.eat.methodtwo;
        dog.eat.methodone(); 
        dogtwo();

 


posted @ 2019-07-01 22:45  Dainney  阅读(1121)  评论(0编辑  收藏  举报