关于javascript的闭包、模块化以及单例模式

为什么放在一起?

模块化本身就自带闭包性质的体现。下面代码:

<span style="white-space:pre">	</span>//定义可多次实例化的模块foo
        function foo () {
            console.log("foo run");
            var num = 0;
            return {
                addNum: function () {
                    num++;
                },
                showNum: function () {
                    console.log(num);
                }
            }
        }

        var bar = foo();
        var zar = foo();
        bar.addNum();
        bar.showNum();
        zar.showNum();

        //使用IIFE的方式实例化模块tar,单例模式
        //IIFE会建立新作用域。这里因为在运行结束后返回了一个含有该作用域引用的函数,形成闭包
        var tar = (function () {
            console.log("tar run");
            var num = 0;
            return {
                addNum: function () {
                    num++;
                },
                showNum: function () {
                    console.log(num);
                }
            }
        })()
        tar.showNum();

什么是闭包呢?看下图:



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值