转 闭包简单理解

链接 : JavaScript中的匿名函数及函数的闭包

1、匿名函数

第一种方式:

var double = function(x) { return 2* x; } 

注意“=”右边的函数就是一个匿名函数,创造完毕函数后,又将该函数赋给了变量square。

 

第二种方式:

(function(x, y){     alert(x + y);   })(2, 3); 

这里创建了一个匿名函数(在第一个括号内),第二个括号用于调用该匿名函数,并传入参数。

2、闭包

闭包的英文单词是closure,这是JavaScript中非常重要的一部分知识,因为使用闭包可以大大减少我们的代码量,使我们的代码看上去更加清晰等等,总之功能十分强大。

闭包的含义:闭包说白了就是函数的嵌套,内层的函数可以使用外层函数的所有变量,即使外层函数已经执行完毕(这点涉及JavaScript作用域链)。

function checkClosure(){
     var str = 'rain-man';
     setTimeout(        
	 function(){ alert(str);
     } //这是一个匿名函数
     , 2000);
} 
checkClosure(); 

执行过程:checkClosure函数的执行是瞬间的(也许用时只是0.00001毫秒),在checkClosure的函数体内创建了一个变量str,在checkClosure执行完毕之后str并没有被释放,这是因为setTimeout内的匿名函数存在这对str的引用。待到2秒后函数体内的匿名函数被执行完毕,str才被释放。

原文地址:https://www.cnblogs.com/xmanblue/p/7589637.html