CommonJs,AMD,CMD,UMD:都是模块化使用规范
CommonJs:
核心思想:模块化,是为了独立作用域【同步】
使用场景:在浏览器之外构建js生态系统
特点:
- 是同步加载
- 具有缓存,被加载过后,后面都直接读取缓存结果,想重新加载模块,需要清除缓存
- 模块可复用
使用:NodeJS
,小程序
基本使用: require
,export
浏览器中使用:CMD
也有在浏览器端的实现,原理是将所有模块都定义好 并通过id
索引,在浏览器环境进行解析
AMD:
核心思想: 模块化【异步】
使用场景: 在浏览器js生态系统
特点:
- 是异步,允许指定回调函数
- 采用
require()
加载模块,但是具有两个参数require(['模块的名字'],callBack)
使用:requireJS
CMD:
大体上和AMD 差不多,同样都是异步加载模块
唯一的区别:CMD
加载时就近原则,AMD
则是依赖前置
CMD
在加载的使用的时候会把模块变为字符串解析一遍才知道依赖了哪个模块;
AMD
和CMD
最大的区别:对依赖模块的执行时机处理不同,而不是加载的时机或者方式不同,二者皆为异步加载模块。
UMD:
是一种思想,就是一种兼容 Commonjs
,AMD
,CMD
的兼容写法,define.amd / define.cmd / module
等判断当前支持什么方式,都不行就挂载到 window
全局对象上面去