JavaScript&JQ 004_JS闭包
2013-05-13 20:02
176 查看
1、什么是闭包 -- 函数嵌套函数 -- 内部函数可以引用外部函数的参数和变量 -- 参数和变量不会被垃圾回收机制回收
<script type="text/javascript"> //1.1函数嵌套函数 function Rabbit() { function shortHairGirl() { } } //1.2内部函数可以引用外部函数的参数和变量 function Rabbit2() { var name="rabbit";//Rabbit2()执行完毕的时候,js垃圾回收器并没有对其回收 //因为shortHairGirl()对其还有引用 function shortHairGirl() { alert(name); } return shortHairGirl; } var loveShortHairGirl=Rabbit2(); //loveShortHairGirl(); //1.3参数和变量不会被垃圾回收机制回收 function GC() { var girl="我是短发美女"; } GC();//当GC()执行完毕的时候,变量girl就会被js垃圾回收器,节省内存 </script>
2、闭包的好处
--希望一个变量长期驻扎在内存当中,避免全局变量的污染
//2.1没有使用闭包 var girlAge=23; function IncAge() { girlAge++; alert("短发美女的芳龄是:"+girlAge); } //IncAge();//24 //IncAge();//25 function IncAge2() { var girlAge=22; girlAge++; alert("短发美女的芳龄是:"+girlAge); } //IncAge2();//23 //IncAge2();//23 function RabbitLoveGirl() { var age=22; return function(){ age++; alert(age); } } var girlAge=new RabbitLoveGirl(); //girlAge(); //girlAge(); //如果一个函数放在()中,那么就变成了函数表达式 ( function aaa(){ alert(2); } )(); (function(){ alert("shit"); })(); var age=(function(){ var a=10; return function(){ a++; alert(a); } })(); age(); age(); </script>
3、 闭包需要注意的地方【IE下可能引发内存泄露】,就不举例了。
4、望眼欲穿,不见一个短发女孩出现。于是乎,我来到了海边.....
相关文章推荐
- javascript深入理解js闭包
- javascript深入理解js闭包
- Javascript模块化编程系列二: 模块化的标准化(CommonJS & AMD)
- atitit.javascript js 上传文件的本地预览
- javascript深入理解js闭包
- 翻译连载 |《你不知道的JS》姊妹篇 |《JavaScript 轻量级函数式编程》- 第 7 章: 闭包 vs 对象
- jQ&js给label
- javascript深入理解js闭包
- js-闭包(closure)&this&arguments对象&懒加载(lazyload)
- (javascript)浅析js函数表达式和函数声明以及闭包
- 我的JavaScript回顾之路_05—0210—js和jq绑定事件的区别/事件冒泡
- Jquery第一篇【介绍Jquery、回顾JavaScript代码、JS对象与JQ对象的区别】
- javascript深入理解js闭包
- javascript深入理解js闭包
- JavaScript - js闭包
- javascript深入理解js闭包
- webView && javascript(JS)的交互
- javascript深入理解js闭包
- javascript深入理解js闭包
- 【js学习1】JavaScript实现&JavaScript插入