关于JS中this指针
解析器在调用函数时每次都会向函数内部传递进隐含参数,这个隐含的参数就是this,this指向得到是一个对象,这个对象称为函数执行的上下文对象。
根据函数的调用方式的不同this会指向不同的对象
1.以函数的形式调用时 this指向全局对象window
2.以方法(obj.sayName())的形式调用时 this就是调用方法的那个对象
3.构造函数内部的this指向新创建的对象
function fun(){
console.log(this.name);
}
window.name = 'Lisa';
fun();// Lisa
1
2
3
4
5
由上可以看出当用函数的形式调用时,this指向的是全局对象window,window可以省略
var obj = {
name:'孙悟空',
sayName:function(){
console.log(this.name);
}
}
obj.sayName();// 孙悟空
1
2
3
4
5
6
7
当以对象的方法调用时发现this指向的是调用方法的对象
function Person(name,age,gender){
// this就是per
this.name = name;
this.age = age;
this.gender = gender;
this.sayName = function(){
alert(this.name);
}
}
var per = new Person('孙悟空',19,'男');
console.log(per);
1
2
3
4
5
6
7
8
9
10
11
从控制台输出内容可以看出this指向的构造函数新创建的对象per,即构造函数的实例
————————————————