闭包

本文介绍了JavaScript中闭包的概念及其实现方式,包括利用闭包实现变量公有、缓存管理、属性私有化及模块化开发等,并强调了闭包可能导致的内存泄漏问题。

一、闭包:当内部函数被保存到外部时,将会生成闭包。闭包会导致原有作用域链不释放,造成内存泄漏。

    //对每一个li ,添加点击事件,利用闭包
        var arrLi=document.getElementsByTagName('li');
        for(var i=0;i<arrLi.length;i++){
            (function(j){
                arrLi[j].onclick=function(){
                    console.log(j)
                }
            }(i))
        }

 

二、闭包作用:

1.实现公有变量,不依赖外部变量 eg:函数累加器

function count(){
    var num=0;
    function add(){
        num++;
        console.log(num);
    }
    return add;
}
var demo=count();
demo();//1
demo()//2

2.可以做缓存

function test(){
    var food='';
    var obj={
        pushFood:function(_food){
           food=_food;
        },
        eatFood:function(){
            console.log('I am eating '+food);
        }
    }
    return obj;
}
var demo=test();
demo.pushFood('apple');//food='apple'
demo.eatFood(); //I am eating apple

3.可以实现封装,属性私有化。 

 

// 继承方法  F为私有化变量
var inherit=(function(){
    function F(){};
    return function(Target,Origin){
        F.prototype=Origin.prototype;
        Target.prototype=new F();
        Target.prototype.constructor=Target;//构造函数指向自己
        Target.prototype.uber=Origin.prototype;//记录继承的对象
    }
}()

 

4.模块化开发,防止污染全局变量
 
        var init=(function(){
            var name=123;
            function test(){
                console.log(name)
            }
            return function(){
                test();
            }
        })();

        init();

 

转载于:https://www.cnblogs.com/yuesu/articles/9455037.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值