什么this
取决于你如何调用你使用的函数this
。
1. 作为函数调用
functionName();
在这种情况下this
将始终引用全局对象(通常是window
对象)。
例子
a = 2;
function XY(a) {
this.a = a;
this.b = function () {
func();
};
function func () {
console.log(this.a);
}
}
var xy = new XY(1);
xy.b(); //2
评论
- 该示例有点构建,但请注意,该函数
func
由简单地调用 write func();
。因此,即使您的函数位于构造函数XY
(this
2.用新关键字调用
var obj = new functionName();
在这种情况下this
将引用新创建的对象。
例子
a = 2;
function XY(a) {
this.a = a;
}
var xy = new XY(1);
console.log(xy.a); //1
3. 作为方法调用
obj.functionName();
在这种情况下this
,将引用包含您正在调用的函数的对象。
例子
a = 2;
var xy = {
a: 1,
func: function() {
console.log(this.a);
}
}
xy.func(); //1
4.使用调用apply
functionName.apply(thisObj, argArray);
在这种情况下,this
将是函数的第一个参数。new Object(thisObj)
thisObj
apply
例子
function xy (a,b) {
console.log(this);
}
xy.apply({f:3}, [1,2]); //Object {f: 3}
xy.apply("hello", [1,2]); //String {0: "h", 1: "e", 2: "l", 3: "l", 4: "o"}
5.由事件处理程序调用
正如用户 Mifeet 所建议的,事件也会改变this
:
事件是一种单独的主题。它们不是 EcmaScript 的一部分,通常由不同的浏览器以不同的方式处理。尽管如此,this
据我所知,关于 IE > 8 的差异很小,并且不存在。
this
将引用触发事件的 DOM 元素,除非您使用内联事件处理程序。在这种情况下this
将引用全局对象。
例子
<button id="1" onclick="clickit()">click me</button> <!-- 0 -->
<button id="2">click me</button>
<button id="3">click me</button>
<script>
var button1 = document.getElementById("1");
var button2 = document.getElementById("2");
var button3 = document.getElementById("3");
id = "0";
window.clickit = function(){
console.log(this.id);
};
button2.onclick = clickit; //2
button3.addEventListener("click", clickit, false); //3
</script>
对事件的评论
- 版本 9 之前的 Internet Explorer 不支持
addEventListener
,但attachEvent
. 使用这个函数也会导致this
引用全局对象。
this
,直接在 HTML 标签内,将引用代表该标签的 DOM 元素。因此<button id="1" onclick="clickit(this)">click me</button>
会将 DOM 元素传递给clickit
事件处理程序。
回到你的案子
在前两种情况下,您将函数作为方法调用,在最后一种情况下,您将其作为函数调用。这就是为什么在最后一种情况下,this
指的是全局对象。
编辑
我最近在 StackOverflow 上看到了一个非常相似的问题的答案。不幸的是,我再也找不到它了,所以我决定自己发布一个答案。但是,如果有人知道我的意思是什么答案,请发表评论,我很乐意在我的答案中添加指向原始答案的链接。