AMD 和 CMD 区别

AMD和 CMD 区别

什么是AMD,CMD?

  • AMD是RequireJS在推广过程中对模块定义的规范化产出;
  • CMD是SeaJS在推广过程中对模块定义的规范化产出;

AMD

  1. AMD是"Asynchronous Module Definition“的缩写,意思就是"异步模块定义”。它采用异步方式加载模块,模块的加载不影响它后面语句的运行。所有依赖这个模块的语句,都定义在一个回调函数中,等到加载完成之后,这个回调函数才会运行。
  2. AMD也采用require()语句加载模块,但是不同于CommonJS,它要求两个参数:
require([module], callback);

CMD

  1. CMD 即Common Module Definition通用模块定义,CMD规范是国内发展出来的,就像AMD有个requireJS,CMD有个浏览器的实现SeaJS,SeaJS要解决的问题和requireJS一样,只不过在模块定义方式和模块加载(可以说运行、解析)时机上有所不同。
  2. 在 CMD 规范中,一个模块就是一个文件。代码的书写格式如下:
define(function(require,exports,module){...});

区别:

  1. 对于依赖的模块,AMD 是提前执行,CMD 是延迟执行。不过 RequireJS 从 2.0 开始,也改成可以延迟执行(根据写法不同,处理方式不同)。CMD 推崇 as lazy as possible.

  2. CMD 推崇依赖就近,AMD 推崇依赖前置。看代码:

// CMD
define(function(require, exports, module) {
var a = require('./a')
a.doSomething()
// 此处略去 100 行
var b = require('./b') // 依赖可以就近书写
b.doSomething()
// ... 
})

// AMD 默认推荐的是
define(['./a', './b'], function(a, b) { // 依赖必须一开始就写好
a.doSomething()
// 此处略去 100 行
b.doSomething()
...
})

虽然 AMD 也支持 CMD 的写法,同时还支持将 require 作为依赖项传递,但 RequireJS 的作者默认是最喜欢上面的写法,也是官方文档里默认的模块定义写法。

猜你喜欢

转载自blog.csdn.net/qq_44352182/article/details/89711728