CMD、AMD、CommonJS 规范

一、CMD(Common Module Definition)通用模块定义

CMD推崇就近依赖,只有在用到某个模块的时候再去require

在 CMD 规范中,一个模块就是一个文件。代码的书写格式如下:

define(factory);

define 是一个全局函数,用来定义模块。define 接受 factory 参数,factory 可以是一个函数,也可以是一个对象或字符串。
factory 为函数时,表示是模块的构造方法。执行该构造方法,可以得到模块向外提供的接口。factory 方法在执行时,默认会传入三个参数:require、exports 和 module:

define(function(require, exports, module) {

  // 模块代码

});
  1. require 是一个方法,接受 模块标识 作为唯一参数,用来获取其他模块提供的接口。
define(function(require, exports) {

  // 获取模块 a 的接口
  var a = require('./a');

  // 调用模块 a 的方法
  a.doSomething();

});
  1. exports 是一个对象,用来向外提供模块接口。
define(function(require, exports) {

  // 对外提供 foo 属性
  exports.foo = 'bar';

  // 对外提供 doSomething 方法
  exports.doSomething = function() {};

});
  1. module 是一个对象,上面存储了与当前模块相关联的一些属性和方法。

应用:SeaJS

/--------------------------------------------------------------------------------------------------------------------------

二、AMD(Asynchronous Module Definition) 异步模块定义

AMD推崇依赖前置,在定义模块的时候就要声明其依赖的模块,AMD 是 RequireJS 在推广过程中对模块定义的规范化的产出。

1.定义模块,函数形式为:

define(id?, dependencies?, factory);

  • id:指定义中模块的名字,可选;如果没有提供该参数,模块的名字应该默认为模块加载器请求的指定脚本的名字。如果提供了该参数,模块名必须是“顶级”的和绝对的(不允许相对名字)。

  • 依赖dependencies:是一个当前模块依赖的,已被模块定义的模块标识的数组字面量。依赖参数是可选的,如果忽略此参数,它应该默认为["require", "exports", "module"]。然而,如果工厂方法的长度属性小于3,加载器会选择以函数的长度属性指定的参数个数调用工厂方法。

  • 工厂方法factory,模块初始化要执行的函数或对象。如果为函数,它应该只被执行一次。如果是对象,此对象应该为模块的输出值。

2.加载模块:

require([module], callback);

[module],是一个数组,里面的成员就是要加载的模块;第二个参数callback,则是加载成功之后的回调函数。

应用:RequireJS


三、CommonJS是服务器端模块的规范,Node.js采用了这个规范。

1.定义模块 根据CommonJS规范,一个单独的文件就是一个模块。每一个模块都是一个单独的作用域,也就是说,在该模块内部定义的变量,无法被其他模块读取,除非定义为global对象的属性

2.模块输出: 模块只有一个出口,module.exports对象,我们需要把模块希望输出的内容放入该对象

3.加载模块: 加载模块使用require方法,该方法读取一个文件并执行,返回文件内部的module.exports对象

浏览器端,加载JavaScript最佳、最容易的方式是在document中插入script标签。但脚本标签天生异步,传统CommonJS模块在浏览器环境中无法正常加载。

应用:Node.js服务器端

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 概念 1、为什么要使用模块化? 当代码规模较大或进行团队协作时,如果不实行模块化,有可能导致命名冲突----解决命...
    周花花啊阅读 827评论 0 3
  • 问答 1.为什么要使用模块化? 要使用模块化,我们要知道什么是模块化?首先一个模块是为了实现特定功能的文件,模块化...
    GarenWang阅读 1,540评论 1 1
  • 示例代码地址 1. 为什么要使用模块化? 1.解决命名冲突 2.代码解耦,提高复用性 3.提高代码可读性 3.方便...
    candy252324阅读 622评论 0 0
  • 一、 为什么要使用模块化? 解决命名冲突 解决依赖管理 提高代码可读性 代码解耦,提高复用性 二、CMD、AMD、...
    Chy18阅读 384评论 0 0
  • 1.为什么要使用模块化? 当去执行某个文件的过程中,如果将全部代码写在同一个文件下,在命名变量时,有些变量是全局变...
    饥人谷_徐小坤阅读 367评论 0 0