您的位置:首页 > Web前端 > JavaScript

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、望眼欲穿,不见一个短发女孩出现。于是乎,我来到了海边.....

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: