美文网首页
AMD(异步加载模块)和CMD(同步加载模块)

AMD(异步加载模块)和CMD(同步加载模块)

作者: Booleanx | 来源:发表于2017-08-29 08:11 被阅读0次

Node服务环境下,使用commonjs规范,每一个js文件下都会有一个全局变量module表示当前模块,其中exports属性用于暴露当前需要共享的属性或方法给外部,其他模块通过require来获取。
1.CommonJS,有一个全局性方法require(),用于加载模块。假定有一个数学模块math.js,就可以像下面这样加载。
  var math = require(‘math‘);
然后,就可以调用模块提供的方法:
  var math = require(‘math‘);
  math.add(2,3); // 5
第二行math.add(2, 3),在第一行require(‘math‘)之后运行,因此必须等math.js加载完成。也就是说,如果加载时间很长,整个应用就会停在那里等。
这对服务器端不是一个问题,因为所有的模块都存放在本地硬盘,可以同步加载完成,等待时间就是硬盘的读取时间。但是,对于浏览器,这却是一个大问题,因为模块都放在服务器端,等待时间取决于网速的快慢,可能要等很长时间,浏览器处于"假死"状态。
因此,浏览器端的模块,不能采用"同步加载"(synchronous),只能采用"异步加载"(asynchronous)。这就是AMD规范诞生的背景。
2:AMD是"Asynchronous Module Definition"的缩写,意思就是"异步模块定义"。它采用异步方式加载模块,模块的加载不影响它后面语句的运行。所有依赖这个模块的语句,都定义在一个回调函数中,等到加载完成之后,这个回调函数才会运行。
AMD也采用require()语句加载模块,但是不同于CommonJS,它要求两个参数:
  require([module], callback);
第一个参数[module],是一个数组,里面的成员就是要加载的模块;第二个参数callback,则是加载成功之后的回调函数。如果将前面的代码改写成AMD形式,就是下面这样:
  require([‘math‘], function (math) {
    math.add(2, 3);
  });//这里是否意味着可以有多个require异步执行,谁先加载完成就先执行自身回调?
math.add()与math模块加载不是同步的,浏览器不会发生假死。所以很显然,AMD比较适合浏览器环境。
目前,主要有两个Javascript库实现了AMD规范:require.jscurl.js
原文:http://www.bubuko.com/infodetail-2224995.html
module:http://javascript.ruanyifeng.com/nodejs/module.html#toc9

相关文章

  • AMD(异步加载模块)和CMD(同步加载模块)

    Node服务环境下,使用commonjs规范,每一个js文件下都会有一个全局变量module表示当前模块,其中ex...

  • 模块化编程--require使用

    AMD--require AMD规范:异步模块加载机制 服务器端 -- 同步加载 浏览器端 -- 异步加载 ...

  • JS 模块化方案对比

    1. CommonJS 规范(同步加载 NodeJS) 2. AMD(异步加载模块 requireJS) 采用异步...

  • AMD

    AMD, Asynchronous Module Definition,即异步模块加载机制,它采用异步方式加载模块...

  • AMD规范和CMD规范

    AMD(异步模块定义规范)制定定义模块的规则,模块和模块的依赖是异步加载的。 AMD通过define()函数定义一...

  • 简述AMD 和 CMD

    AMD AMD推崇依赖前置,在定义模块的时候就要声明其依赖的模块同样都是异步加载模块,AMD在加载模块完成后就会执...

  • JS模块化

    这是一个关于JS模块化的扫盲贴。 列举一下我们会遇到的一些概念: AMD,CMD,CommonJs,同步加载,异步...

  • js的模块方案:CommonJS、AMD和CMD

    什么是CommonJS、AMD和CMD CommonJS、AMD和CMD都是js的模块加载方案,JS在最初设计的时...

  • Webpack笔记

    webpack 笔记 Webpack 是一个模块加载器,它同时支持AMD、CMD加载规范。与其他模块化加载器相比,...

  • CommonJS规范与AMD/CMD规范总结

    CommonJS规范加载模块是同步的,只有加载完成,才能执行后面的操作。AMD规范是非同步加载模块,允许指定回调函...

网友评论

      本文标题:AMD(异步加载模块)和CMD(同步加载模块)

      本文链接:https://www.haomeiwen.com/subject/sjnndxtx.html