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/
网友评论