最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

详解Javascript的闭包工作原理

来源:动视网 责编:小采 时间:2020-11-27 19:56:16
文档

详解Javascript的闭包工作原理

详解Javascript的闭包工作原理:所谓的闭包就是一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分。我这边的理解是:其实在js中所有的function方法其实都可以算作是闭包,简单来说也可以理解为是嵌套function方法的使用:如下面的代码例
推荐度:
导读详解Javascript的闭包工作原理:所谓的闭包就是一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分。我这边的理解是:其实在js中所有的function方法其实都可以算作是闭包,简单来说也可以理解为是嵌套function方法的使用:如下面的代码例


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

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

相关推荐:

闭包 最详细的闭包解释

文档

详解Javascript的闭包工作原理

详解Javascript的闭包工作原理:所谓的闭包就是一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分。我这边的理解是:其实在js中所有的function方法其实都可以算作是闭包,简单来说也可以理解为是嵌套function方法的使用:如下面的代码例
推荐度:
标签: 工作 原理 详解
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top