网上的博客和文章关于this指针的有很多,但是每篇文章都是作者自己的心得和理解,其他人理解起来会有偏差,正如岳肃蔡子峰二人根据正本葵花宝典以及自己的理解默写出葵花宝典的残本、林远图根据残本与少林修为写出辟邪剑谱,所以要得到自己的理解就要看正本的“葵花宝典”,我所看的就是猫头鹰书cody lindley所写的《JavaScript启示录》。
this值会被传递给所有函数,其值基于运行时调用函数的上下文,而不是它所定义的位置。例子如下:
var slm={ <span style="white-space:pre"> </span>name:"mumu", <span style="white-space:pre"> </span>age:24, <span style="white-space:pre"> </span>sex:"male", <span style="white-space:pre"> </span>showName:function(){ <span style="white-space:pre"> </span>console.log(this.name); <span style="white-space:pre"> </span>} } var slm2={ <span style="white-space:pre"> </span>name:"mumu2", <span style="white-space:pre"> </span>age:24, <span style="white-space:pre"> </span>sex:"male", <span style="white-space:pre"> </span>showName:slm.showName } slm2.showName();//mumu2
如果一个函数里没有调用的对象,那么this默认为全局变量window
var name="mumu"; function showName(){ <span style="white-space:pre"> </span>console.log(this.name); } showName();//mumu当this值的宿主函数被封装在另一个函数的内部或另一个函数的上下文中被调用时,this的值将永远是对window对象的引用。
例子就如阮一峰的关于闭包问题的思考题,如下:
var name = "The Window"; var object = { name : "My Object", getNameFunc : function(){ return function(){ return this.name; }; } }; alert(object.getNameFunc()());//The Window
var name = "slm"; var obj1= { name: "mumu", showName: function(){ alert(this.name); } }; var obj2 = { name: "handsome_mumu", showName: function(){ var show = obj1.showName; show(); } }; obj2.showName(); //slm
解决以上问题方法就是在父函数使用作用域链保留对this的引用,使this不丢失。
var slm={ name:"slm", age:24, sex:"male", show:function(){ var that=this; var showme=function (){ console.log(that.name); <span style="white-space:pre"> </span>}(); } }还有就是使用call()、apply()、bind()函数定义this的作用域。