JavaScript this关键字
this是 JavaScript 语言的一个关键字。它是函数运行时,在函数体内部自动生成的一个对象,只能在函数体内部使用。函数的不同使用场合,this指向的对象也不同.总的来说,this就是函数运行时所在的环境对象。下面分四种情况,详细讨论this的用法。
情况一:纯粹的函数调用
这是函数的最通常用法,属于全局性调用,因此this就代表全局对象。
var x = 1;
function test() {
console.log(this.x);
}
test(); // 1
情况二:作为对象方法的调用
当作为对象的方法调用,这时this指向这个方法所属的对象。
function test() {
console.log(this.x);
}
var obj = {};
obj.test = test;
obj.x = 1;
obj.test(); // 1
情况三: 作为构造函数调用
所谓构造函数,就是通过这个函数,生成一个新对象,这时,this就指这个新对象。
var x = 2;
function test() {
this.x = 1;
}
var obj = new test();
console.log(x) //2,表明全局变量x的值没变
情况四: apply 调用
apply()能改变当前函数的调用对象。它的第一个参数就表示要调用这个函数的对象,这时this指的就是这个对象。当参数为空时,默认为全局对象。
var x = 0;
function test() {
console.log(this.x);
}
var obj = {};
obj.x = 1;
obj.m = test;
obj.m.apply() // 0
obj.m.apply(obj); //1