🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
## CommonJS,AMD,CMD区别 > commonjs是用在服务器端的,同步的,如nodejs > amd, cmd是用在浏览器端的,异步的,如requirejs和seajs > 其中,amd先提出,cmd是根据commonjs和amd基础上提出的。 ## CommonJS `CommonJS`是以在浏览器环境之外构建 JavaScript 生态系统为目标而产生的项目,比如在服务器和桌面环境中,`Node.JS`遵循`CommonJS`的规范 `CommonJS`规范是为了解决`JavaScript`的作用域问题而定义的模块形式,可以使每个模块它自身的命名空间中执行。该规范的主要内容是,模块必须通过`module.exports`导出对外的变量或接口,通过`require()`来导入其他模块的输出到当前模块作用域中。 举例说明: ~~~ var clock = require('clock'); clock.start(); ~~~ `CommonJS`是同步加载模块 ## AMD((Asynchromous Module Definition) 基于`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`就近依赖,需要使用把模块变为字符串解析一遍才知道依赖了那些模块