javascript 模块化编程----模块的写法
一、原始写法
模板就是实现特定功能的一组方法
只要把不同的函数(以及记录状态的变量)简单地放在一起,就算是一个模块。
  function m1(){
    //...
  }
  function m2(){
    //...
  }
上面的函数m1()和m2(),组成一个模块。使用的时候,直接调用就行了。
这种做法的缺点很明显:"污染"了全局变量,无法保证不与其他模块发生变量名冲突,而且模块成员之间看不出直接关系。
二、对象写法
为了解决上面的缺点,可以把模块写成一个对象,所有的模块成员都放到这个对象里面。
var module1 = new Object({
_count : 0,
m1 : function (){
//...
},m2 : function (){
//...
}});
上面的函数m1()和m2(),都封装在module1对象里。使用的时候,就是调用这个对象的属性。
module1.m1();
但是,这样的写法会暴露所有模块成员,内部状态可以被外部改写。比如,外部代码可以直接改变内部计数器的值。
module1._count = 5;
三、立即执行函数写法
使用 立即执行函数,可以达到不暴露私有成员的目的。
var model1=(function(){
      var count=0;
      var fun1=function (){
          console.log("this is function1");
      };
      var fun2=function (){
          console.log("this is function2");
      }
      return {
          fun1:fun1,
          fun2:fun2
      }
  })();
使用上面的方法,外部代码无法读取count变量
console.log(model1.count)//undefined
这是JavaScript模板的基本写法。
四、放大模式
如果一个模块很大,必须分成几个部分,或者一个模板需要继承另一个模块,这时就有必要采用‘放大模式’
var model2=(function(mode){
        mode.fun3=function (){
            console.log("this is function3");
        };
        return mode
    })(model1);
model2继承model1,并添加方法fun3,输出model2,有fun1 fun2 fun3 三个方法,因为model1中count没有暴露,所以在model2中无法访问model1中的count
model1中也添加新方法fun3
五、宽放大模式
在浏览器环境中,模块的各个部分通常都是从网上获取的,有时无法知道哪个部分会先加载,如果采用上一节的写法,第一个执行的部分有可能加载一个不存在的对象,这是就要采用‘宽放大模式’。
var module1 = ( function (mod){
    //...
    return mod;
  })(window.module1 || {});
与‘放大模式’相比,‘宽放大模式’就是‘立即执行函数’的参数可以是空对象。
六、 输入全局变量
独立性是模块的重要特点,模块内部最好不与程序的其他部分直接交互。
为了在模块内部调用全局变量,必须显式地将其他变量输入模块。
var module1 = (function ($, YAHOO) {
    //...
  })(jQuery, YAHOO);
上面的module1模块需要使用jQuery库和YUI库,就把这两个库(其实是两个模块)当作参数输入module1。这样做除了保证模块的独立性,还使得模块之间的依赖关系变得明显。
原文出处:http://www.ruanyifeng.com/blog/2012/11/require_js.html
javascript 模块化编程----模块的写法的更多相关文章
- Javascript模块化编程(一):模块的写法
		
Javascript模块化编程(一):模块的写法 作者: 阮一峰 原文链接:http://www.ruanyifeng.com/blog/2012/10/javascript_module.html ...
 - Javascript模块化编程(一):模块的写法(转)
		
随着网站逐渐变成"互联网应用程序",嵌入网页的Javascript代码越来越庞大,越来越复杂. 网页越来越像桌面程序,需要一个团队分工协作.进度管理.单元测试等等......开发者 ...
 - Javascript模块化编程(一):模块的写法 作者: 阮一峰
		
声明:转载自阮一峰的网络日志 随着网站逐渐变成"互联网应用程序",嵌入网页的Javascript代码越来越庞大,越来越复杂. 网页越来越像桌面程序,需要一个团队分工协作.进度管理. ...
 - Javascript模块化编程(一):模块的写法 (转载  学习中。。。。)
		
转载地址:http://www.ruanyifeng.com/blog/2012/10/javascript_module.html 阮一峰 大神:http://www.ruanyifeng.com/ ...
 - Javascript模块化编程(一):模块的写法【转】
		
作者: 阮一峰 日期: 2012年10月26日 随着网站逐渐变成"互联网应用程序",嵌入网页的Javascript代码越来越庞大,越来越复杂. 网页越来越像桌面程序,需要一个团队分 ...
 - Javascript模块化编程:模块的写法
		
声明:本文转载自:阮一峰的网络日志,原文地址http://www.ruanyifeng.com/blog/2012/10/javascript_module.html,http://www.ruany ...
 - [转] Javascript模块化编程(一):模块的写法
		
随着网站逐渐变成"互联网应用程序",嵌入网页的Javascript代码越来越庞大,越来越复杂. 网页越来越像桌面程序,需要一个团队分工协作.进度管理.单元测试等等......开发者 ...
 - Javascript模块化编程(一)模块的写法最佳实践六、输入全局变量  独立性是模块的重要特点,模块内部最好不与程序的其他部分直接交互。  为了在模块内部调用全局变量,必须显式地将其他变量输入模块。
		
Javascript模块化编程,已经成为一个迫切的需求.理想情况下,开发者只需要实现核心的业务逻辑,其他都可以加载别人已经写好的模块但是,Javascript不是一种模块化编程语言,它不支持类clas ...
 - (转)Javascript模块化编程(一):模块的写法
		
随着网站逐渐变成"互联网应用程序",嵌入网页的Javascript代码越来越庞大,越来越复杂. 网页越来越像桌面程序,需要一个团队分工协作.进度管理.单元测试等等......开发者 ...
 
随机推荐
- 14Spring通过注解配置Bean(2)
			
下面将对13Spring通过注解配置Bean(1)的中Repository.Service.Controller通过注解方式来建立关联. <context:component-scan>元 ...
 - Volume 1. Sorting/Searching(uva)
			
340 - Master-Mind Hints /*读了老半天才把题读懂,读懂了题输出格式没注意,结果re了两次. 题意:先给一串数字S,然后每次给出对应相同数目的的一串数字Si,然后优先统计Si和S ...
 - Python之基础练习题
			
Python之基础练习题 1.执行 Python 脚本的两种方式 2.简述位.字节的关系 解:8位是一个字节 3.简述 ascii.unicode.utf-8.gbk 的关系 4.请写出 “李杰” 分 ...
 - Fiddler基本用法:手机抓包
			
from:https://blog.csdn.net/gld824125233/article/details/52588275 电脑最好是笔记本,这样能和手机保持统一局域网内:其他不多说,直接说步骤 ...
 - 【转】Java读写文件大全
			
使用Java操作文本文件的方法详解 最初java是不支持对文本文件的处理的,为了弥补这个缺憾而引入了Reader和Writer两个类,这两个类都是抽象类,Writer中 write(ch ...
 - noip模拟赛 单词
			
分析:这道题真心难想.最主要的是怎么样不重复. 为了不重复统计,把所有符合条件的单词分成两类,一类是某些单词的前缀,一类是 不是任何单词的前缀.涉及到前缀后缀,维护两个trie树,处理3个数组a,b, ...
 - AtCoder Grand Contest 020 D - Min Max Repetition
			
q<=1000个询问,每次问a,b,c,d:f(a,b)表示含a个A,b个B的字符串中,连续A或连续B最小的串中,字典序最小的一个串,输出这个串的c到d位.a,b<=5e8,d-c+1&l ...
 - Java中如何获取spring中配置的properties文件内容
			
有2种方式: 一. 1.通过spring配置properties文件 [java] <bean id="propertyConfigurer" class=&qu ...
 - u启动为苹果笔记本重装win7系统教程
			
准备更换系统的苹果笔记本一台! 上述需要准备的东西均准备好以后我们就开始今天的教程了!! 首先,将已经制作好启动盘的u启动u盘插入到苹果笔记本上的usb插口,然后开机! 由于苹果笔记本电脑 ...
 - 命令行man的帮助手册
			
http://blog.csdn.net/gatieme/article/details/51656707 指定使用那种语音的手册,可以使用命令选项-M man -M /usr/share/man/z ...