this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁,一般情况下this的最终指向的是那个调用它的对象。
1. 全局作用域或者普通函数中this指向全局对象window(注意定时器里面的this指向window)
// 1. 全局作用域或者普通函数中this指向全局对象window(注意定时器里面的this指向window) console.log(this); // 普通函数是window的属性方法(window.fn();),所以指向的是window function fn() { console.log(this); } window.setTimeout(function() { console.log(this); }; 1000);
2. 方法调用中谁调用this就指向谁
// 2. 方法调用中谁调用this就指向谁 var o = { sayHi: function() { console.log(this); // this指向的是 o 这个对象 } } o.sayHi(); btn.addEventListener(‘click‘, function() { console.log(this); // this指向的是 btn 这个按钮对象 })
3. 构造函数中this指向构造函数的实例
// 3. 构造函数中this指向构造函数的实例 function Fun() { console.log(this); // this指向的是fun实例对象 } var fun = new Fun();