视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
详解Javascript的闭包工作原理
2020-11-27 19:56:16 责编:小采
文档


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

我这边的理解是:其实在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的值。

相关推荐:

闭包 最详细的闭包解释

下载本文
显示全文
专题