技术解析

JS 关于 this 指向的疑惑
0
2021-08-12 08:49:09
idczone

//代码 var name = '行星飞行'; let obj = { name: '听风是风', fn: function () { console.log(this.name); } };

function fn1(param) { param(); }; fn1(obj.fn);

这个例子中我们将 obj.fn 也就是一个函数传递进 fn1 中执行,这里只是单纯传递了一个函数而已,this 并没有跟函数绑在一起,所以 this 丢失这里指向了 window 。

上述是一篇文章中讲述的,我有点没搞清楚“this 并没有跟函数绑在一起,所以 this 丢失这里指向了 window”这句话到底表述了什么意思...


var name = "行星飞行";
let obj = {
name: "听风是风",
fn: function () {
console.log(this.name);
//哪个对象调用该方法,this 即指向该对象
},
};
function fn1(fn) {
/*
这里的 fn 只是个方法,同 function () {
console.log(this.name);
}
该方法已经和 obj 对象没有关系了,所以最终的 this 就指向了兜底对象 window 对象,里面的 this 就是 window
虽然 fn 在 fun1 里执行,但是 fn 不属于 fn1,这里只是借用的关系
*/
fn();
}
fn1(obj.fn);

我有点理解了,谢谢你

总结楼上:this 指向最后一次调用的对象。

数据地带为您的网站提供全球顶级IDC资源
在线咨询
专属客服