CommonJS
CommonJS
是以在浏览器环境之外构建 JavaScript 生态系统为目标而产生的项目,比如在服务器和桌面环境中,Node.JS
遵循CommonJS
的规范
CommonJS
规范是为了解决 JavaScript
的作用域问题而定义的模块形式,可以使每个模块它自身的命名空间中执行。该规范的主要内容是,模块必须通过 module.exports
导出对外的变量或接口,通过 require()
来导入其他模块的输出到当前模块作用域中。
举例说明:
var clock = require('clock');
clock.start();
CommonJS
是同步加载模块
AMD
基于CommonJS
规范的nodeJS
出来以后,服务端的模块概念已经形成,很自然地,大家就想要客户端模块。而且最好两者能够兼容,一个模块不用修改,在服务器和浏览器都可以运行。但是,由于一个重大的局限,使得CommonJS
规范不适用于浏览器环境。如果将上面的代码运行在客户端浏览器,就会报错。
上面的require
方法是同步的。这对服务器端不是一个问题,因为所有的模块都存放在本地硬盘,可以同步加载完成,等待时间就是硬盘的读取时间。但是,对于浏览器,这却是一个大问题,因为模块都放在服务器端,等待时间取决于网速的快慢,可能要等很长时间,浏览器处于"假死"状态。
因此,浏览器端的模块,不能采用"同步加载",只能采用"异步加载"。这就是AMD
规范诞生的背景。
CommonJS是主要为了JS在后端的表现制定的,他是不适合前端的,AMD出现了,它就主要为前端JS的表现制定规范。
AMD
是Asynchronous Module Definition
的缩写,意思就是"异步模块定义"。它采用异步方式加载模块,模块的加载不影响它后面语句的运行。所有依赖这个模块的语句,都定义在一个回调函数中,等到加载完成之后,这个回调函数才会运行。
AMD
也采用require()
语句加载模块,但是不同于CommonJS
,它要求两个参数:
require([module], callback);
require(['clock'],function(clock){
clock.start();
});
requireJs
就是AMD
规范的实现
CMD
CMD
(Common Module Definition), 是seajs
推崇的规范,CMD
则是依赖就近,用的时候再require
。它写起来是这样的:
define(function(require, exports, module) {
var clock = require('clock');
clock.start();
});
AMD
和CMD
最大的区别是对依赖模块的执行时机处理不同,而不是加载的时机或者方式不同,二者皆为异步加载模块。
AMD
依赖前置,js
可以方便知道依赖模块是谁,立即加载;而CMD
就近依赖,需要使用把模块变为字符串解析一遍才知道依赖了那些模块