美文网首页
高级4:AMD_CMD_RequireJS

高级4:AMD_CMD_RequireJS

作者: 饥人谷_严琰 | 来源:发表于2017-11-03 21:10 被阅读0次

    题目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

    相关文章

      网友评论

          本文标题:高级4:AMD_CMD_RequireJS

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