AMD 和 CMD 的区别有哪些?
作者:玉伯
链接:https://www.zhihu.com/question/20351507/answer/14859415
来源:知乎

AMD 规范在这里:https://github.com/amdjs/amdjs-api/wiki/AMD
CMD 规范在这里:https://github.com/seajs/seajs/issues/242

AMD 是 RequireJS 在推广过程中对模块定义的规范化产出。
CMD 是 SeaJS 在推广过程中对模块定义的规范化产出。
类似的还有 CommonJS Modules/2.0 规范,是 BravoJS 在推广过程中对模块定义的规范化产出。
还有不少⋯⋯

这些规范的目的都是为了 JavaScript 的模块化开发,特别是在浏览器端的。
目前这些规范的实现都能达成浏览器端模块化开发的目的

区别:

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 的作者默认是最喜欢上面的写法,也是官方文档里默认的模块定义写法。

3. AMD 的 API 默认是一个当多个用,CMD 的 API 严格区分,推崇职责单一。比如 AMD 里,require 分全局 require 和局部 require,都叫 require。CMD 里,没有全局 require,而是根据模块系统的完备性,提供 seajs.use 来实现模块系统的加载启动。CMD 里,每个 API 都简单纯粹

4. 还有一些细节差异,具体看这个规范的定义就好,就不多说了。

另外,SeaJS 和 RequireJS 的差异,可以参考:https://github.com/seajs/seajs/issues/277

AMD 和 CMD 的区别有哪些? (玉伯)相关推荐

  1. AMD和CMD的区别,转载玉伯在知乎上的回答。

    AMD 规范在这里:https://github.com/amdjs/amdjs-api/wiki/AMD CMD 规范在这里:https://github.com/seajs/seajs/issue ...

  2. 前端模块化,AMD与CMD的区别

    在JavaScript发展初期就是为了实现简单的页面交互逻辑,寥寥数语即可:如今CPU.浏览器性能得到了极大的提升,很多页面逻辑迁移到了客户端(表单验证等),随着web2.0时代的到来,Ajax技术得 ...

  3. AMD和CMD的区别

    他们两者的共同点就是都是一种框架在推广的过程中对模块定义的规范产出:而且他们都是异步加载模块. AMD即Asynchronous Module Definition,翻译过来就是异步模块化定义,是一个 ...

  4. 【AMD和CMD的区别】

    最主要的是: AMD是预加载,CMD是懒加载.AMD是提前执行,CMD是延迟执行. amd (在对应的加载之前导入),cmd(在用的时候导入). 以下为相关补充: AMD AMD 即Asynchron ...

  5. 再谈 JS中的模块规范(CommonJS,AMD,CMD)来自玉伯的seajs分析

    随着互联网的飞速发展,前端开发越来越复杂.本文将从实际项目中遇到的问题出发,讲述模块化能解决哪些问题,以及如何使用 Sea.js 进行前端的模块化开发. 恼人的命名冲突 我们从一个简单的习惯出发.我做 ...

  6. 前端开发 AMD 和 CMD 的规范区别

    AMD 规范在这里:https://github.com/amdjs/amdjs-api/wiki/AMD CMD 规范在这里:https://github.com/seajs/seajs/issue ...

  7. JavaScript模块化 --- Commonjs、AMD、CMD、es6 modules

    随着前端js代码复杂度的提高,JavaScript模块化这个概念便被提出来,前端社区也不断地实现前端模块化,直到es6对其进行了规范,下面就介绍JavaScript模块化. 这篇文章还是希望能给大家一 ...

  8. 理解AMD ,CMD,CommonJS规范

    https://blog.csdn.net/xcymorningsun/article/details/52709608 理解AMD ,CMD,CommonJS规范 2016年09月30日 10:33 ...

  9. 彻底理解AMD和CMD

    一个模块就是实现特定功能的文件,有了模块,我们就可以更方便地使用别人的代码,想要什么功能,就加载什么模块.模块开发需要遵循一定的规范,各行其是就都乱套了. AMD AMD 规范是 CommonJS 模 ...

最新文章

  1. Android(Linux)实时监控串口数据
  2. R语言tidyr包gather()函数实战详解:数据收缩、从宽表到窄表
  3. wireshark过滤规则学习总结
  4. wxWidgets:wxXLocale类用法
  5. java地图点线面_openlayers之点,线,面(以城市,河流,省份为例,分别对应点线面)...
  6. 生产者消费者---线程管道
  7. Zabbix4.2安装和4.0升级4.2笔记
  8. 【Linux】ubuntu 16 启动拨号上网
  9. Spring.profile实现开发、测试和生产环境的配置和切换
  10. 用户需求和分析——张有亮
  11. 44. Wildcard Matching (String; DP, Back-Track)
  12. 各种语言和各种前沿技术的简介和科普
  13. C++-导出类-导出宏-纯虚函数-DllMain函数-调用约定与参数命名
  14. idea Push Tags选All还是Current Branch?
  15. macmini作为远程服务器,我在用我的 Mac mini 做什么
  16. php error_reporting(0);,php error_reporting()函数的用法举例(错误捕捉)
  17. 什么原因可能会造成Android手机卡顿?
  18. java反编译工具gd gson,浅谈Android中static修饰符,及Gson转String实例
  19. python框架之Scrapy自动存储mysql数据库
  20. [Python3] 线程池的使用

热门文章

  1. python部落翻译_python利用google翻译 翻译字幕文件
  2. layer真是一个不错的web弹层组件
  3. turtlebot2利用turtlebot_exploration_3d进行自主建图
  4. Linux Ubuntu VM15虚拟机安装VMwareTools新手教程
  5. android日志框架
  6. 转载 ARM Linux 3.10.61 的启动 —— (一)解压缩阶段
  7. Wasserstein CNN: Learning Invariant Features for NIR-VIS Face Recognition
  8. java Jedis连接池的使用
  9. 微信小程序毕业设计 基于微信花店鲜花小程序商城系统开题报告
  10. 顶级会议与SCI论文关系