this是个老生常谈的问题了,this有很多种情况,比如在原型中,严格模式,DOM事件中,对象方法中都有一定问题,就针对你的这个问题,我是这样理解的,在执行上下文中,this的指向只是与如何调用这个方法有关,how the function is called,这里有什么关系呢?你这里一个闭包,里面的自执行匿名函数不属于任何对象,他不是一个对象的方法(你如何使用点运算符调用?),也就是说他不属于任何一个对象,在非严格模式中,无指向的 函数内部的this,指向window.
为什么要使用this,为了解决什么问题?
其实,引入this的初衷就是想在原型继承的情况下,拿到函数的调用者。
通过闭包可以访问外部函数作用域中的变量。
但每个函数在被调用时都会自动取得两个特殊变量: this 和 arguments。内部函数在搜索这两个变量时,只会搜索到其自己活动对象为止(找到了就不用沿着作用域链继续找了)因此永远不可能 直接访问外部函数中的这两个变量。
匿名函数的执行环境具有全局性,因此其 this 对象通常指向 window。
另外关于this指向的一些总结
但每个函数在被调用时都会自动取得两个特殊变量: this 和 arguments。内部函数在搜索这两个变量时,只会搜索到其自己活动对象为止(找到了就不用沿着作用域链继续找了)因此永远不可能 直接访问外部函数中的这两个变量。
匿名函数的执行环境具有全局性,因此其 this 对象通常指向 window。
(function(){
alert(this===window)
})();
另外关于this指向的一些总结
- 全局环境中的this就是全局对象,在浏览器即window
- 构造器中的this就是新创建出来的对象
- 函数中的this指向函数的调用者
- new Function中的this指全局对象
- eval中的this指调用上下文中的this
改变调用方法中的this
其实很简单:对象实例化之后的this指的是本身,未实例化则this指的是调用者的对象