关于JS中的闭包浅谈
作者:
闭包是一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分
( ⊙o⊙ )!!!这个也太尼玛官方了撒,作为菜鸟的我根本无法理解它想表达个什么意思!但是作为一只好奇的菜鸟又很想知道“闭包”到底是个什么东西!所以最终找到了传说中的“度娘”帮忙!还算有了一点小小的理解!
个人见解:在函数体内定义另外的方法函数,而这个方法函数被函数以外的变量引用,这时就形成了闭包!
可能这样的理解也太抽象了,并不是那么简单易懂!实例吧:
复制代码 代码如下:
<script type="text/javascript">
function A(){
var S=0;
function B(){
alert(++S);
}
return B;
}
var C=A();
C();
</script>
上面这一段代码就创建了一个闭包,因为当函数执行到var C=A();时,表面上看C指向的是A函数,而实际上C所指向的函数是B函数,所以再执行到C()的时候就会输出2;这样的话B函数就被A函数以外的变量引用了,根据个人见解,创建了一个闭包!
当我在小小的了解了什么时候闭包后也顺便看了哈闭包的用途,据说闭包的用途主要有两点:
1、可以读取函数内部的变量
2、让这些变量始终保持在内存中
复制代码 代码如下:
<script type="text/javascript">
function A(){
var S=1;
D=function(){
S+=1;
}
function B(){
alert(S);
}
return B;
}
var C=A();
C(); // 输出1
D();
C(); // 输出2
</script>
上面的代码中C指向的还是是B函数,C执行了两次,第一次输出1,第二次输出2,这证明了S一直被保存在内存中,并没有在A函数在被调用后自动清除,这是为什么呢,原因是因为B函数被赋给了一个全局变量,这导致了B函数一直在内存中,而B函数的执行又需要依赖着A函数,所以A也一直在内存中,不会在调用结束后被回收!(这样的理解貌似有点不专业)!
表达完毕,请广大群众多多指教!
您可能感兴趣的文章:
- JavaScript中的作用域链和闭包
- 深入理解JavaScript 闭包究竟是什么
- JS中批量给元素绑定事件过程中的相关问题使用闭包解决
- 深入Javascript函数、递归与闭包(执行环境、变量对象与作用域链)使用详解
- javascript闭包传参和事件的循环绑定示例探讨
- 一不小心就做错的JS闭包面试题
- 一道JS前端闭包面试题解析
- javascript从作用域链谈闭包
- 谈一谈javascript闭包
- 浅析JavaScript作用域链、执行上下文与闭包
- JS面向对象(3)之Object类,静态属性,闭包,私有属性, call和apply的使用,继承的三种实现方法
- Javascript闭包与函数柯里化浅析
- JavaScript中闭包的写法和作用详解