闭包实现封装

Posted 党兴明

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了闭包实现封装相关的知识,希望对你有一定的参考价值。

1 闭包实现封装

var oj= (function(){  
    var _age= 0;  
    var func1= function(){  
      return _age+1; 
    };  
    var func2= function(){  
      return _age+2;  
    };  
    return {  
      m1 : func1,  
      m2 : func2  
    };  
})(); 

2 为上面的方法添加新方法

var obj =(function (f){  
    f.func3= function () {  
      return ‘方法模式‘;
    };  
    return f;//方便方法连续调用  
})(oj);//新模块obj继承oj的方法,并增加一个
alert(obj.m1());
alert(obj.m2());
alert(obj.func3());

3 上边的可能在oj没有加载,就执行obj模块,所以可以这样

var obj =(function (f){  
    f.func3= function () {  
      return ‘方法模式‘;
    };  
    return f;//方便方法连续调用  
})(window.oj|| {});

4 输入全局变量:独立性是模块的重要特点,模块内部最好不与程序的其他部分直接交互。为了在模块内部调用全局变量,必须显式地将其他变量输入模块。

   这是jQuery框架的源码,将window对象作为参数传入,这样做除了保证模块的独立性,还使得模块之间的依赖关系变得明显。

 

(function(window, undefined ) {  
  ……  
})(window ); 

 

以上是关于闭包实现封装的主要内容,如果未能解决你的问题,请参考以下文章

将自己写的代码进行闭包封装

Spark闭包与序列化

VsCode 代码片段-提升研发效率

VSCode自定义代码片段14——Vue的axios网络请求封装

VSCode自定义代码片段14——Vue的axios网络请求封装

VSCode自定义代码片段14——Vue的axios网络请求封装