this指向问题!!!

235 阅读1分钟

1、this 指向问题 一般情况下this的最终指向的是那个调用它的对象

2、全局作用域或者普通函数中this指向全局对象window( 定时器里面的this指向window)

3、方法调用中谁调用this指向谁

4、构造函数中this指向构造函数的实例

<body>
<button>点击</button>
<script>
// this 指向问题 一般情况下this的最终指向的是那个调用它的对象
// 1. 全局作用域或者普通函数中this指向全局对象window( 定时器里面的this指向window)

console.log(this);   //window

function fn() {
    console.log(this);   //window
}

window.fn();
window.setTimeout(function() {
    console.log(this);    //window
}, 1000);

// 2. 方法调用中谁调用this指向谁
var o = {
    sayHi: function() {
        console.log(this); // this指向的是 o 这个对象
    }
}

o.sayHi();
var btn = document.querySelector('button');
btn.onclick = function() {
    console.log(this); // this指向的是btn这个按钮对象
}

btn.addEventListener('click', function() {
        console.log(this); // this指向的是btn这个按钮对象
    })
    
 // 3. 构造函数中this指向构造函数的实例
function Fun() {
    console.log(this); // this 指向的是fun 实例对象
}
var fun = new Fun();
</script>
</body>