闭包!关于闭包的全面理解,一看就懂!

如何理解闭包!

要理解闭包,首先必须理解 Javascript 特殊的变量作用域。
变量的作用域分类:全局变量和局部变量。
特点:
1、函数内部可以读取函数外部的全局变量;在函数外部无法读取函数内的局部变量。
2、函数内部声明变量的时候,一定要使用 var 命令。如果不用的话,你实际上声明了一个
全局变量!

1、闭包定义和用法:

当一个函数的返回值是另外一个函数,而返回的那个函数如果调用了其父
函数内部的其它变量,如果返回的这个函数在外部被执行,就产生了闭包。

或者(1)可以访问其他函数内部变量的函数就叫闭包函数
(2)定义在函数内部的函数
(3)函数嵌套函数

2、表现形式:使函数外部能够调用函数内部定义的变量。

3、实例如下:

(1)、根据作用域链的规则,底层作用域没有声明的变量,会向上一级找,找到就返回,没找
到就一直找,直到 window 的变量,没有就返回 undefined。这里明显 count 是函数内部的
flag2 的那个 count 。

var count=10; //全局作用域 标记为 flag1
function add(){
var count=0; //函数全局作用域 标记为 flag2
return function(){
count+=1; //函数的内部作用域
alert(count);
}
}
var s = add()
s();//输出 1
s();//输出 2

2:闭包两种实例:

1:

function a(){
            var k=1;
            function b(){
                console.log(k);// 1;
            }
        }
        a();

2:

function a(){
             var k=1;
            return function (){
                 console.log(k);// 1;
             }
         }
         a()();

3:使用闭包的注意点
(1)滥用闭包,会造成内存泄漏:由于闭包会使得函数中的变量都被保存在内存中,内存消
耗很大,所以不能滥用闭包,否则会造成网页的性能问题,在 IE 中可能导致内存泄露。解
决方法是,在退出函数之前,将不使用的局部变量全部删除。

(2)会改变父函数内部变量的值。所以,如果你把父函数当作对象(object)使用,把闭包当
作它的公用方法(Public Method),把内部变量当作它的私有属性(private value),这时一
定要小心,不要随便改变父函数内部变量的值。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值