相信大家对这三种规范有一定的了解,今天在这里我就把这个梳理一下,加深印象!
AMD规范:全称”Asynchronous Module Definition”,称为 异步模块加载规范 。一般应用在浏览器端。流行的浏览器端异步加载库RequireJS实现的就是AMD规范。
CMD规范,全称”Common Module Definition”,称为 通用模块加载规范。一般也是用在浏览器端。浏览器端异步加载库Sea.js实现的就是CMD规范。
CommonJS: 称为同步模块加载规范,也就是说,只有加载完成,才能执行后面的操作。
AMD特点: 依赖前置,提前执行!
代码块
define(['jquery','underscore'], function($, _) {
//methods
function a(){}; //私有方法
function b(){}; //公有方法
return {
b: b
}
})
define是AMD 规范用来声明模块接口,示例中的第一个参数是一个数组,表示当前模块的依赖。第二个参数是一个回调函数,表示此模块的执行体。只有当依赖数组中的所有依赖模块都是可用的时,AMD模块加载器(比如RequireJS)才会去执行回调函数并返回此模块的暴露接口。
注意,回调函数中参数的顺序与依赖数组中的依赖顺序一致。(即:jquery->$,underscore->_)
当然,在这里我可以将回调函数的参数名称改成任何我们想用的可用变量名,这并不会对模块的声明造成任何影响。
除此之外,你不能在模块声明的外部使用$或者_,因为他们只在模块的回调函数体中才有定义。
CMD特点: 依赖就近,延迟执行!
代码块
define(function(require, exports, module){
var a = require('./a');
a.doSomething();
var b = require('./b');
b.doSomething();
});
CMD与AMD区别
对于依赖的模块,AMD 是提前执行,CMD 是延迟执行。
CMD 推崇依赖就近,AMD 推崇依赖前置。
·······
CommonJS规范
代码块
// filename: foo.js
// dependencies
var $ = require('jquery');
// methods
function myFunc() {};
// exposed public method (single)
module.exports = myFunc;
上边是使用CommonJS规范声明一个名为foo模块的方式,同时依赖jquery模块。
AMD规范与CommonJS规范的兼容性
CommonJS规范加载模块是同步的,也就是说,只有加载完成,才能执行后面的操作。
AMD规范则是非同步加载模块,允许指定回调函数。
Node.js遵循CommonJS规范。这是因为Node.js主要用于服务器编程,模块文件一般都已经存在于本地硬盘,所以加载起来比较快,不用考虑非同步加载的方式。但如果是浏览器环境,要从服务器端加载模块,这时就必须采用非同步模式,因此浏览器端一般采用AMD规范
有问题或者意见建议,欢迎大家直接找我,谢谢!
参考文献:http://blog.gejiawen.com/2014/07/18/small-talk-about-fe-spec/