javascript 匿名函数和模块化

  任何变量,函数,数组,对象,只要不在函数内部,都被认为是全局的,这就是说,这个页面上的其它脚本也可以访问它,而且可以覆盖重写它。

  解决办法是,把你的变量放在一个匿名函数内部,定义完之后立即调用它。封装


        var myApplication = function(){
             var name = 'Chris';
             var age = '34';
             var status = 'single';
             return{
                 createMember:function(){
                     // [...]
                 },
                 getMemberDetails:function(){
                     // [...]
                 }
             }
        }();
 	//myApplication.createMember() 和
 	//myApplication.getMemberDetails() 就可以使用了。
这被称作 module 模式或 singleton。Douglas Crockford 多次谈到过这些,Yahoo User Interface Library YUI 里对此有大量的使用

        var myApplication = function(){
             var name = 'Chris';
             var age = '34';
             var status = 'single';
             function createMember(){
                     // [...]
             }
             function getMemberDetails(){
                     // [...]
             }
             return{
                     create:createMember,
                     get:getMemberDetails
             }
        }();
 	//现在写成 myApplication.get()和 myApplication.create() 就行了。
把需要能被外界访问的元素的指针导出来,简化了外界调用的写法
      

  

转载于:https://www.cnblogs.com/sallet/p/4115444.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值