js中this到底是啥意思啊?
<scripttype="text/javascript">varname="TheWindow"varobject={name:"Myobject",getNameFu...
<script type="text/javascript">
var name="The Window"
var object={
name:"My object",
getNameFunc:function(){
return function(){
return this.name;
}
}
}
var object={
name:"My object",
getNameFunc:function(){
var that=this;
return function(){
return that.name;
}
}
}
alert(object.getNameFunc()());
</script>
弹出的为什么是the window?又为什么是My object 求详解 展开
var name="The Window"
var object={
name:"My object",
getNameFunc:function(){
return function(){
return this.name;
}
}
}
var object={
name:"My object",
getNameFunc:function(){
var that=this;
return function(){
return that.name;
}
}
}
alert(object.getNameFunc()());
</script>
弹出的为什么是the window?又为什么是My object 求详解 展开
1个回答
展开全部
第一个this.name指的是变量name(对应var name="The Window"这个),
第二个this.name指的是object这个map里面的name,this指的是object这个map对象。
this是Javascript语言的一个关键字它代表函数运行时,自动生成的一个内部对象,只能在函数内部使用,下面分四种情况:
情况一:纯粹的函数调用 :这是函数的最通常用法,属于全局性调用,因此this就代表全局对象Global。
情况二:作为对象方法的调用 :函数还可以作为某个对象的方法调用,这时this就指这个上级对象。
情况三 作为构造函数调用 :所谓构造函数,就是通过这个函数生成一个新对象(object)。这时,this就指这个新对象。
情况四 apply调用 :apply()是函数对象的一个方法,它的作用是改变函数的调用对象,它的第一个参数就表示改变后的调用这个函数的对象。因此,this指的就是这第一个参数。
第二个this.name指的是object这个map里面的name,this指的是object这个map对象。
this是Javascript语言的一个关键字它代表函数运行时,自动生成的一个内部对象,只能在函数内部使用,下面分四种情况:
情况一:纯粹的函数调用 :这是函数的最通常用法,属于全局性调用,因此this就代表全局对象Global。
情况二:作为对象方法的调用 :函数还可以作为某个对象的方法调用,这时this就指这个上级对象。
情况三 作为构造函数调用 :所谓构造函数,就是通过这个函数生成一个新对象(object)。这时,this就指这个新对象。
情况四 apply调用 :apply()是函数对象的一个方法,它的作用是改变函数的调用对象,它的第一个参数就表示改变后的调用这个函数的对象。因此,this指的就是这第一个参数。
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询