解析器在调用函数每次都会向函数内部传递进一个隐含的参数
这个隐含的参数就是this,this指向的是一个对象
这个对象我们称为函数执行的上下文对象
根据函数的调用方式不同,this会指向不同的对象
一般情况下
判断方法(待补充)
1,以函数的形式调用时,this永远都是window
2,以方法的形式调用时,this就是调用方法的那个对象(谁调用this,this就是谁)
3,看函数执行的时候前面有没有点,有点,点前面是啥this就是啥,没点就是window
4,给元素的某一个事件绑定一个方法如(button.onclick = fn()),当事件触发执行方法,
方法中的this就是当前元素(button)
function fun(a,b){
console.log("a = "+a+",b = "+b)
console.log(this); //[object Window]
}
fun(123,456)
var person = {
name:"钢铁侠",
sex:"男",
show:function(){
alert(person.name);
alert(this.name);//两者输出结果一样
}
}
person.show()
function show(){
alert(this)
}
show() //obj window
window.show() //obj window
window.onload = function(){
var obtn = document.getElementById("btn")
obtn.onclick = function(){
alert(this);//指向button
}
}
<button id="btn">button</button>