AMD 、CMD、CommonJS

作者: 天外来人 | 来源:发表于2017-02-16 16:06 被阅读40次

AMD规范:

AMD规范: 全称"Asynchronous Module Definition", 称为异步模块加载规范。一般应用在浏览器端。requireJS遵循的就是AMD规范。
特点: 依赖前置,提前执行

define(['jquery','underscore'], function($, _) {
  //methods
  function a(){}; //私有方法
  function b(){}; //公有方法
  
  return {
    b: b
 }
})

define是AMD 规范用来声明模块接口,示例中的第一个参数是一个数组,表示当前模块的依赖。第二个参数是一个回调函数,表示此模块的执行体。只有当依赖数组中的所有依赖模块都是可用的时,AMD模块加载器(如requeryJS)才会去执行回调函数并返回此模块的暴露接口。

CMD规范:

CMD规范 全称"Common Module Definition", 称为通过模块加载规范。一般也是用在浏览器端。Sea,js 遵循的是CMD规范。
特点: 依赖就近,延迟执行。

define(function(require, exports, module){
  var a = require('./a');
  a.doSomething();
  var b = require('./b');
  b.doSomething();
});

AMD 与 CMD 总结:

  • 对于依赖的模块,AMD 是提前执行,CMD 是延迟执行。
  • CMD 推崇依赖就近,AMD 推崇依赖前置。

CommonJS规范

CommonJS: 称为同步模块加载规范,也就是说,只有加载完成,才能执行后面的操作。
Node.js遵循CommonJS规范。这是因为Node.js主要用于服务器编程,模块文件一般都已经存在于本地硬盘,所以加载起来比较快,不用考虑非同步加载的方式。但如果是浏览器环境,要从服务器端加载模块,这时就必须采用非同步模式,因此浏览器端一般采用AMD规范。
下面是使用CommonJS规范声明一个名为foo模块的方式,同时依赖jquery模块。

// filename: foo.js
// dependencies
var $ = require('jquery');

// methods
function myFunc() {};

// exposed public method (single)
module.exports = myFunc;

参考文献:
http://blog.gejiawen.com/2015/11/03/what-is-amd-cmd-commonjs-umd/
http://blog.gejiawen.com/2014/07/18/small-talk-about-fe-spec/

相关文章

网友评论

    本文标题:AMD 、CMD、CommonJS

    本文链接:https://www.haomeiwen.com/subject/cvkhwttx.html