1. 对于依赖的模块,AMD 是提早执行,CMD 是延迟执行。不过 RequireJS 从 2.0 开始,也改为能够延迟执行(根据写法不一样,处理方式不一样)。CMD 推崇 as lazy as possible.jquery
2. CMD 推崇依赖就近,AMD 推崇依赖前置。看代码:git
// CMD
define(function(require, exports, module) {
var a = require('./a')
a.doSomething()
// 此处略去 100 行
var b = require('./b') // 依赖能够就近书写
b.doSomething()
// ...
})github
// AMD 默认推荐的是
define(['./a', './b'], function(a, b) { // 依赖必须一开始就写好
a.doSomething()
// 此处略去 100 行
b.doSomething()
...
}) api
虽然 AMD 也支持 CMD 的写法,同时还支持将 require 做为依赖项传递,但 RequireJS 的做者默认是最喜欢上面的写法,也是官方文档里默认的模块定义写法。数组
3. AMD 的 API 默认是一个当多个用,CMD 的 API 严格区分,推崇职责单一。好比 AMD 里,require 分全局 require 和局部 require,都叫 require。CMD 里,没有全局 require,而是根据模块系统的完备性,提供 seajs.use 来实现模块系统的加载启动。CMD 里,每一个 API 都简单纯粹。dom
4. 还有一些细节差别,具体看这个规范的定义就好,就很少说了。异步
1.seajs.config--用来对 Sea.js 进行配置。async
seajs.config({ // 设置路径,方便跨目录调用 paths: { 'domes': 'http://127.0.0.1:8020/seajs-master' }, // 设置别名,方便调用 alias: { 'dom': 'domes/dome/dom' }, // 变量配置 vars: { 'locale': 'zh-cn' } });
seajs.use('dom',function(d){ //=> 加载的是 http://127.0.0.1:8020/seajs-master/dome/dom.js d.d(); });
别名起到了变量的做用,'dom'表明'domes/dome/dom','domes'表明'http://127.0.0.1:8020/seajs-master' 则'domes/dome/dom'解析为http://127.0.0.1:8020/seajs-master/dome/dom.js。函数
变量配置工具
define(function(require, exports, module){ // 获取模块 dom_1 的接口 var som=require('./dom/{locale}.js'); //加载的地址http://127.0.0.1:8020/seajs-master/dome/dom/zh-cn.js som.s(); exports.dom_2=function(){ console.log("dom_2"); }; });
{locale}就表明'zh-cn'
2.seajs.use
// 加载一个模块 seajs.use('./a'); // 加载一个模块,在加载完成时,执行回调 seajs.use('./a', function(a) { a.doSomething(); }); // 加载多个模块,在加载完成时,执行回调 seajs.use(['./a', './b'], function(a, b) { a.doSomething(); b.doSomething(); });
3.define--用来定义模块
define(id?, deps?, factory)
也能够接受两个以上参数。字符串 id 表示模块标识,数组 deps 是模块依赖。好比:
define('hello', ['jquery'], function(require, exports, module) {
});
id 和 deps 参数能够省略。省略时,能够经过构建工具自动生成。
注意:带 id 和 deps 参数的 define 用法不属于 CMD 规范,而属于 Modules/Transport 规范。
define(function(require, exports, module) { //exports 用来在模块内部对外提供接口。 // 对外提供 foo 属性 exports.foo = 'bar'; // 对外提供 doSomething 方法 exports.doSomething = function() {}; //注意:require, exports, module这三个回掉函数参数切勿改变。 });
4.require--用来获取指定模块的接口
//注意,require 只接受字符串直接量做为参数,详细约定请阅读 //require.async 用来在模块内部异步加载一个或多个模块。 define(function(require) { // 获取模块 a 的接口 var a = require('./a'); // 调用模块 a 的方法 a.doSomething(); // 异步加载多个模块,在加载完成时,执行回调 require.async(['./c', './d'], function(c, d) { c.doSomething(); d.doSomething(); }); });
5.exports--用来在模块内部对外提供接口
define(function(require, exports, module) { //exports 用来在模块内部对外提供接口。 // 对外提供 foo 属性 exports.foo = 'bar'; // 对外提供 doSomething 方法 exports.doSomething = function() {}; //注意:require, exports, module这三个回掉函数参数切勿改变。 });
6.module.exports--用来在模块内部对外提供接口
define(function(require, exports, module) { // 对外提供接口 module.exports = { name: 'a', doSomething: function() {}; }; });
与 exports 相似,用来在模块内部对外提供接口。
7.require.resolve(id)--用来获取指定模块的绝对路径
define(function(require, exports, module){ // 获取模块 dom_1 的接口 var som=require('./dom_2'); console.log(require.resolve('./dom_2'),'用来获取指定模块的绝对路径'); });
这个能够用来检测你加载模块时候,路径是否正确。
做者:玉伯
连接:https://www.zhihu.com/question/20351507/answer/14859415
来源:知乎
著做权归做者全部。商业转载请联系做者得到受权,非商业转载请注明出处。
参考:https://github.com/seajs/seajs/issues/242
参考:https://github.com/amdjs/amdjs-api/wiki/AMD
参考:https://github.com/seajs/seajs/issues/266
参考:http://yslove.net/seajs/
amd与cmd是一种规范,而目前两大加载器(seajs,requirejs)应用的规范是不一样的。cmd推荐的是依赖就近原则,用到就加载。而amd则是依赖前置。只有加载才可使用。相对于来讲cmd比较符合使用习惯。