JS中this指针的指向

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();

猜你喜欢

转载自www.cnblogs.com/zcy9838/p/12951994.html