码迷,mamicode.com
首页 > 其他好文 > 详细

Jq this的指向问题

时间:2019-07-01 23:04:48      阅读:205      评论:0      收藏:0      [点我收藏+]

标签:fun   情况   one   col   done   OLE   anim   log   dog   

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();

 


Jq this的指向问题

标签:fun   情况   one   col   done   OLE   anim   log   dog   

原文地址:https://www.cnblogs.com/Dainney/p/11117299.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!