首页 > web前端 > js教程 > 正文

详解Javascript的闭包工作原理

零到壹度
发布: 2018-04-08 16:05:04
原创
1212 人浏览过

所谓的闭包就是一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分。

我这边的理解是:其实在js中所有的function方法其实都可以算作是闭包,简单来说也可以理解为是嵌套function方法的使用:

如下面的代码例子:

function run(){
   var a=10;
    return function(){
	a++;
	console.log(a);
    }
}
var foo=run();
foo();//11
foo();//12 
foo();//13
登录后复制

解析:此时的foo的值就等于run()函数的返回值,foo函数就是一个闭包;

1)执行的流程是先调用foo()方法,foo()这个方法会找到run()方法里面的返回函数方法,这个返回函数方法会指向run()方法里面的a变量,然后再执行foo()时,会输出11;

2)在上面的例子中,由于闭包的存在使得函数run返回后,run()中的a始终存在,这样每次执行foo(),a都是自加1后console出a的值。

 相关推荐:

到底什么是闭包

闭包 最详细的闭包解释

深入理解js 闭包

以上是详解Javascript的闭包工作原理的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!