JavaScript很多书籍都讲的唧唧歪歪一大堆,不知道讲些什么
1、什么是闭包
-- 函数嵌套函数
-- 内部函数可以引用外部函数的参数和变量
-- 参数和变量不会被垃圾回收机制回收
2、闭包的好处
--希望一个变量长期驻扎在内存当中,避免全局变量的污染
3、 闭包需要注意的地方【IE下可能引发内存泄露】,就不举例了。
转载自http://www.cnblogs.com/zjflove/archive/2013/05/13/3076392.html
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下可能引发内存泄露】,就不举例了。
转载自http://www.cnblogs.com/zjflove/archive/2013/05/13/3076392.html