JavaScript闭包(closure)
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript闭包(closure)相关的知识,希望对你有一定的参考价值。
闭包(closure)
闭包是javascript语言的一个难点,需要有足够的逻辑思维能力。
一、变量的作用域
变量分为两种:全局变量和局部变量。
1.在函数内部是可以直接读取到全局变量的,如下:
var n = 10; function fn(){ alert(n); } fn(); alert结果为10.
2.在函数外部肯定是无法读取到函数内的局部变量的,如下
function f(){ var n = 20; }
f(); alert(n); 程序会报错:n is no defined.
注意:大家在这个地方需要注意是,在函数内部声明变量的时候,一定加var。如果不加,相当于声明了一个全局变量。
二、如何在外部可以读取到局部变量了。
我们这里就引入这个闭包,来实现,就是在一个函数内在引入一个函数。
function f1(){ var n = 10; function f2(){ alert (n); } return f2; } var result = f1(); result(); 结果就为:10
三、什么叫闭包
闭包:就是能够读取其它函数内部函数的变量。
其实可以简单的理解为:定义在一个函数内部的函数,像比如上面例子中的函数f2()。
闭包在本质上就是将函数内部和函数外部连接在一起的桥梁。
四、闭包的用处
1.可以读取函数内部的变量。
2.变量持久化(变量的值始终会保存在内存中)。
function f1(){ var n = 10; return function(){ n++; alert(n); } } var result = f1(); //外部函数赋给变量result; result(); //result函数第一次执行,结果为11; result(); //result函数第二次执行,结果为12,实现了累加,
上面这个例子就完美诠释了变量的持久化。
3.模块化代码,减少全局变量的污染。
var abc = (function(){ //abc为外部匿名函数的返回值 var a = 1; return function(){ a++; alert(a); } })(); abc(); //2 ;调用一次abc函数,其实是调用里面内部函数的返回值 abc(); //3
五、使用闭包应注意的问题
1.由于闭包会使函数内部中的变量都保存在来,内存消耗很大。所以不能滥用闭包,否则会造成网页的性能问题。
六、最后告诉大家:其实闭包是Javascript语言的一个难点,也是它的特色,很多高级应用才会用到闭包,所以刚学的同学不懂也不要着急,在以后的不断学习中,会慢慢理解的!
以上是关于JavaScript闭包(closure)的主要内容,如果未能解决你的问题,请参考以下文章