登录
首页 >  文章 >  前端

JavaScript闭包如何让匿名函数访问外部函数的this?

时间:2024-11-05 10:09:47 482浏览 收藏

一分耕耘,一分收获!既然打开了这篇文章《JavaScript闭包如何让匿名函数访问外部函数的this?》,就坚持看下去吧!文中内容包含等等知识点...希望你能在阅读本文后,能真真实实学到知识或者帮你解决心中的疑惑,也欢迎大佬或者新人朋友们多留言评论,多给建议!谢谢!

JavaScript闭包如何让匿名函数访问外部函数的this?

javascript闭包作用域困局:专家解惑

假设我们有以下代码:

<pre>
var name = "the window";
var object = {

name: "My Object",
getNameFunc: function() {
    return function() {
        return this.name;
    };
}

};
alert(object.getnamefunc()());
</pre>

在这种情况下,会出现一个闭包作用域问题。匿名函数的this一般指向window。

代码的第一部分,getnamefunc对应的function的this指向object。但是,该函数返回了另一个函数,并且该函数是匿名的,这意味着this指向window。

代码的第二部分,通过闭包,让匿名函数引用getnamefunc的局部变量that(实际上是getnamefunc的this)。

当匿名函数执行并寻找that变量时,它自己没有这个变量,所以它会向上查找that。此时,that引用的是getnamefunc的this,即object。

因此,alert()显示my object

终于介绍完啦!小伙伴们,这篇关于《JavaScript闭包如何让匿名函数访问外部函数的this?》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>