this指向

this 在非严格模式下总是指向一个对象

在任何函数体外部,this 都指向window

要判断this的内容,一定要去寻找调用位置,也只有调用位置才能决定this的指向内容。而不是声明的位置。

默认绑定

//默认绑定
function foo() {
            console.log(this)//window
            console.log(this.name)//this指向的是window,this.name在window中寻找叫`name`的和键值对 
        }
        var name = 'danny'
        foo()

当一个函数是直接使用不带任何修饰的函数引用进行调用的,那么就是默认绑定,函数内的this指向的就是全局对象。

隐式绑定

function foo() { 
    console.log( this.a );
    console.log(this)//Object

}
var obj = {
    a: 2,
    foo: foo
};
obj.foo(); // 2

无论foo是在obj里定义,还是obj外定义,严格意义上来说foo都是不属于obj这个对象的,foo仍然是一个独立的函数。

当一个函数是隶属于某个对象来调用的,那么就会触发隐式绑定规则,函数内的this指向的就是绑定到这个对象的上下文。

参考:如何确定this的指向 - 掘金 (juejin.cn)

posted @ 2023-03-18 09:56  Dou-D  阅读(20)  评论(0)    收藏  举报