码迷,mamicode.com
首页 > 编程语言 > 详细

javascript之this

时间:2018-05-23 13:03:20      阅读:139      评论:0      收藏:0      [点我收藏+]

标签:color   javascrip   nbsp   call   调用   对象   直接   返回   原型   

总结一句话:javascript函数里的this,始终指向调用该函数的直接对象。当然通过apply(),call(),bind()这几个方法可以更改this除外

实例1:alert(this === window);  //true            调用该函数的直接对象是全局window

 

实例2:var test = function() { alert(this === window)}; test(); //true          调用该函数的直接对象仍是全局window

 

实例3:var test = function() { alert(this === window)}; new test(); //false       因为new关键字创建了一个空对象,相当于由这个空对象作为构造函数调用的直接对象,此时this就不是指向window而是指向空对象,并将空对象进行初始化作为返回值。

 

实例4:var test = { ‘a‘: 1, ‘b‘: function(){ alert(this === test);}}; test.b() //true     这是test作为函数test.b调用的直接对象

 

实例5: var test = {‘a‘: 1, ‘b‘: {‘b1‘: function(){ alert(this === test.b); }}}; test.b.b1();  //true   这时test.b作为函数test.b.b1调用的直接对象 

 

实例6: var test = function(){ var inner = function(){ alert(this === window);} inner(); }; test();  //true   类似闭包函数里的this,无论多少层,调用函数的直接对象始终为全局window

 

实例7: 关于原型链继承   var test = function(){};  var test2 = function(){ this.a = function(){ alert(this === p1);}}; var p2 = new test2(); test.prototype = p2; test.prototype.constructor = test;var p1 = new test(); p1.a(); //true      此时p1作为函数p2.a调用的直接对象

 

实例8:dom节点事件监听函数的this  <div onclick="shw(this)"></div>   此时的this指向节点元素对象

 

javascript之this

标签:color   javascrip   nbsp   call   调用   对象   直接   返回   原型   

原文地址:https://www.cnblogs.com/huanqiuxuexiji/p/9076243.html

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