1.谁作为拥有者调用它就指向谁
function a() {
console.log(this);
}
var b = {};
b.hehe = a;
b.hehe();
//这时候this指向b//常见的就是绑定事件
2.bind谁就指向谁
function a() {
console.log(this);
}
var b = {};
var c = {};
b.hehe = a.bind(c);
b.hehe();
//这时候this指向c//如果你用bind的话
3.没有拥有者,直接调用,就指向window
function a() {
console.log(this);
}
a();
//this指向window
4.call谁就是谁,apply谁就是谁,其实bind就是通过call和apply实现的
其中2覆盖掉1
2020-02-09 更新
5.es6的箭头方法,this指向箭头方法定义的命名空间的this
function a (){
this.init = function(){
document.getElementById('button').onclick = (p1)=>{
console.log(this); //this指向 a类的实例
}
}
}
let b = new a();
b.init();