<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<script>
**//闭包
/*什么是闭包?
在外部函数foo()内再声明一个内部函数fn(),内部函数fn()可以操作访问外部函数foo()中的n变量,但是外部函数不可以访问内部函数fn()的变量
*/
/*为什么引入闭包?
因为在正常机制中,我们无法在函数外部操作函数内部的变量,比如下面的例子,我们无法在foo()函数外部直接操作foo()函数里面的n变量进行加加减减,
但是我们可以在内部函数fn()中写入对外部变量n的加加减减操作,然后在外部函数结束时返回内部函数,这样就可以在foo()函数外部通过调用内部函数fn()来
对n变量进行加减操作
*/**
function foo(){
var n=1;
function fn(){
n++;
console.log(n);
}
return {n:n,fn:fn};
}
console.log(result);//{n: 1, fn: ƒ}
//相当于返回
/*result={
n:1,
fn:fn
}*/
var result=foo();
var result2=foo();
console.log(result.n);//1
console.log(result2.n);//1 说明执行完外部foo()后 变量会被垃圾回收机制回收
result.fn(); //2
result.fn(); //3 说明闭包执行完内部函数后,外部函数的变量不会被回收
</script>
</body>
</html>
闭包中对变量的回收操作
最新推荐文章于 2023-08-20 17:07:15 发布