JavaScript-js 闭包
var name="kitty";
var object={
name:"my object",
getnamefunc:function(){
var that=this
return function(){
alert(this)
return this.name
};
}
}
alert(object.getnamefunc()())
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
js中的this指向与Java/C++这些静态语言不同,他取决于"调用时的方式",这点在ECMA规范中有详细说明,原文比较复杂就不贴了,我平时跟初学者解释时,一般会简化为:
虽然不完整没有涉及到base object,global scope之类的东东,但对于初学者是很好理解的。这里最重要的就是“调用时”,即this是运行期决定的,例如:
var x, y, z;
x = {
name: "I'm X",
method: function() { console.log(this); }
};
y = {
name: "I'm Y"
}
y.method = x.method;
z = x.method;
x.method();
y.method();
z();
这个结果第一次是点前面的x,第二次是点前面的y,第三次因为没写点(.)所以是window
对于你的情况,最后的object.getnamefunc()()相当于:
var x = object.getnamefunc();
x();
所以当然是window
this还是他的上下文环境相关的 object.getnamefunc()这步完了之后 就相当于一个普通的全局函数当然就是指向了window
this 对象是在运行时基于函数的执行环境绑定的,如果this在全局范围就是window,如果在对象内部就指向这个对象。而闭包却在运行时指向window的,因为闭包并不属于这个对象的属性或方法。
你始终记着 this 是调用这个方法的对象的引用, 谁调用的这个方法就是谁.