高级4:AMD_CMD_RequireJS

题目1: 为什么要使用模块化?

  • 可以避免命名冲突
  • 对文件的依赖项进行统一管理
  • 提高代码的可读性和维护性
  • 提高页面的性能

题目2: CMD、AMD、CommonJS 规范分别指什么?有哪些应用

  • CommonJS 规范:根据 CommomJS 规范,一个单独的文件就是一个模块。每一个模块都是一个单独的作用域,也就是说,在该模块内部定义的变量,无法被其他模块读取,除非定义为global对象的属性。这个规范同时定义了 module.exports 对象为模块的出口,我们需要把想要输出的内容放到 module.exports 对象中;定义了 require 方法为加载模块的方式。这一规范主要应用在服务端的JS,即NodeJS上。例子如:
// 这里是a.js
var name = 'a';

// 输出name
module.exports = {
  name: name
}
// 这里是b.js
var a = require('a'); // 使用require方法加载模块,并返回模块内部的 module.exports 对象
a.name; // a
  • AMD 规范:AMD 规范的意思是异步模块定义的意思,由 RequireJS 在推广模块化定义的过程中产出。 这个规范用于浏览器模块化的开发,主要解决了两个问题:
    1. 多个js文件可能有依赖关系,被依赖的文件需要早于依赖它的文件加载到浏览器
    2. 加载的时候浏览器会停止页面渲染,加载文件越多,页面失去响应时间越长
      例子如:
// 这里是a.js
// define函数的第一个参数为依赖项数组,即想要加载的模块:例如jquery
// 第二个参数为回调函数,等模块加载完毕后会把加载的模块传到回调函数里
define(['jquery'], function ($) {
  var name = 'a';

  return {
    name: name
  }  // 这里是模块输出,让别的模块能够使用
});
// 这里是b.js
// 加载模块a
// 等到所有模块都加载完毕后再执行回调函数并把模块传到回调函数
require(['jquery', 'a'] function ($, a) {
  a.name; // a
})
  • CMD 规范:CMD 规范与 AMD 规范类似,但两者的模块加载时机和模块定义的方式不同。使用这个规范的主要是 SeaJS,例子如:
// 这里是a.js
define(function (require, module, exports) {
  var $ = require('jquery'); // 与AMD规范不同的是,CMD规范是要用到模块的时候再加载,而AMD规范是先把所有模块加载完后再用
  $('div').addClass('active');
})
// 这里是b.js
// 使用模块a
seajs.use(['a.js'], function(a){
  // todo
});

题目3: 使用 requirejs 完善入门任务15,包括如下功能

代码地址:https://github.com/a625689014/requirejs
预览地址:https://a625689014.github.io/requirejs/page.html

注:预览链接加载时间较长,瀑布流图片墙在本地mock成功


image.png

推荐阅读更多精彩内容

  • 1: 为什么要使用模块化? 解决命名冲突 依赖管理 提高代码可读性 代码解耦,提高复用性 2: AMD、Commo...
    晓风残月1994阅读 121评论 0 0
  • 题目1: 为什么要使用模块化?答:解决命名冲突依赖管理提高代码可读性代码解耦,提高复用性 题目2: CMD、AMD...
    饥人谷_桶饭阅读 119评论 0 1
  • 课程任务 题目1: 为什么要使用模块化? 模块化的作用有以下这些: 可以解决命名冲突 管理依赖 提高代码的可读性 ...
    ReedSun_QD阅读 311评论 0 0
  • 随着前端业务复杂度的增加,模块化成为一个大的趋势。而在ES6还未被浏览器所支持的情况下,commonjs作为ES6...
    吴高亮阅读 822评论 0 3
  • 为什么要使用模块化? 最主要的目的:解决命名冲突依赖管理 其他价值提高代码可读性代码解耦,提高复用性 CMD、AM...
    Eazer阅读 363评论 3 1