JavaScript - this 关键字(十)
JS this 关键字
- 面向对象语言中 this 表是当前对象的一个引用
- 但是,在 JS 环境中 this 不是固定不变的,它会随着执行环境的改变而改变
- 在方法中,this 表示该方法所属的对象
- 单独使用,this 表示全局对象
- 在函数中,this 表示全局对象
- 在函数中,严格模式下,this 是未定义的(undefined)
- 在事件中,this 表示接收事件的元素
- 类似 call() 和 apply() 方法可以将 this 引用到任何对象
实例:
var person = {
firstName:"John",
lastName:"Doe",
id:555,
fullName:function() {
return this.firsstName + " " + this.lastName;
}
};
// 这里的 this 用在方法中,表示该方法所属的对象 person
方法中的 this
- 在对象方法中,this 指向调用它所在的方法的对象
- 在以上实例中,this 表示 person 对象
- fullName 方法所属的对象就是 person
fullName:function() {
return this.firstName + " " + this.lastName;
}
单独使用 this
- 单独使用 this,则指向全局(Global)对象
- 在浏览器中,window 就是该全局对象 [object Window]
var x = this;
- 在严格模式下,如果单独使用,this 也是指向全局(Global)对象
"use strict"
var x = this;
函数中使用 this(默认)
- 在函数中,函数的所属者默认绑定到 this 上
- 在浏览器中,window 就是该全局对象 [object Window]
function myFunction() {
return this;
}
函数中使用 this(严格模式下)
- 严格模式下,函数是没有绑定到 this 上的,这时候 this 是 undefined
"use strict"
function myFunction() {
return this;
}
事件中的 this
- 在 HTML 事件的句柄中,this 指向了接收事件的 HTML 元素
- 以下 this 指向的是接收 onclick 事件的 button 元素
<button onclick="this.style.display='none'">
点我后我就消失了
</button>
对象方法中绑定
- 下面实例中,this 是 person 对象,person 对象是函数的所有者:
var person = {
firstName:"John",
lastName:"Doe",
id:555,
myFunction:function() {
return this; // this 指向了 fullName 方法所属的对象 person
}
}
显示函数绑定
- 在 JS 中,函数也是对象,对象则有方法,apply 和 call 就是函数对象的方法
- 这两个方法异常强大,他们允许切换函数执行的上下文环境(context),即 this 绑定的对象
- 在下面的实例中,当我们使用 person2 作为参数来调用 person1.fullName 方法时,this 将指向 pereson2,即便它是 person1 的方法
var person1 = {
fullName:function() {
return this.firstName + " " + lastName;
}
};
var person2 = {
firstName:"John",
lastName:"Doe",
}
person1.fullName.call(person2); // 返回 "John Doe"