作为一个菜鸟学到js函数中的this关键字时就被搞的头昏了,值随时都在变,,,
专研了一下,看了很多大佬的说法,我理了理写下自己对this的理解吧,列举三个常用的
this是Javascript语言的一个关键字。
它代表函数运行时,自动生成的一个内部对象,只能在函数内部使用。
this的值会随着函数使用的变化而变化,但是this总是指向调用函数的那个对象
1.普通的函数调用
var x = 1;
function test(){
alert(this.x);
}
test();//1
所得结果为1,是window调用的函数,所以这里的this指的是全局对象
为了更好说明this现在是全局对象,对代码再做一下改变
var x = 2;
function test(){
this.x = 1;
}
test();
alert(x);//1
所得结果是1,不是2,
就类似于 x = 1,
所以可知this指的是全局对象
2.作为对象的方法调用
function test(){
alert(this.x);
}
var a = {};
a.x = 1;
a.y = test; //test函数作为对象a的方法被调用
a.y(); //1
此时this指的就是其上级对象a
3.作为构造函数调用
function test(){
this.x = 1;
}
var a = new test();
alert(a.x);//1
所得结果为1,此时this指的就是定义的新对象a。