美文网首页
高级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

    1: 为什么要使用模块化? 解决命名冲突 依赖管理 提高代码可读性 代码解耦,提高复用性 2: AMD、Commo...

  • 高级4:AMD_CMD_RequireJS

    题目1: 为什么要使用模块化? 可以避免命名冲突 对文件的依赖项进行统一管理 提高代码的可读性和维护性 提高页面的...

  • 高级4 - AMD_CMD_RequireJS

    课程任务 题目1: 为什么要使用模块化? 模块化的作用有以下这些: 可以解决命名冲突 管理依赖 提高代码的可读性 ...

  • 高级任务4:AMD_CMD_RequireJS

    题目1: 为什么要使用模块化? 使用模块化可以: 解决命名冲突; 可进行依赖管理; 增强代码的可读性; 代码解耦,...

  • 高级任务4(AMD_CMD_RequireJS)

    题目1: 为什么要使用模块化? 前端开发中,起初只要在script标签中嵌入几十上百行代码就能实现一些基本的交互效...

  • web前端-深入(4)-AMD_CMD_RequireJS

    题目1: 为什么要使用模块化? 解决命名冲突 依赖管理 提高代码可读性 代码解耦,提高复用性 题目2: CMD、A...

  • 高级4

    题目1: 为什么要使用模块化?使用模块化有如下好处:解决命名冲突:文件过多时,容易早餐全局变量冲突依赖管理:当一个...

  • 高级4

    题目1: 为什么要使用模块化?最主要的目的解决命名冲突 假设有100个js文件,不能够知道这个命名有没有冲突...

  • Log4j2进阶使用(更多高级特性)

    1.高级进阶说明 本文介绍Log4j2高级进阶使用,基于Log4j2进阶使用(按大小时间备份日志),介绍更多的高级...

  • AMD_CMD_RequireJS

    1. 为什么要使用模块化? 背景:如今CPU、浏览器性能得到了极大的提升,很多页面逻辑迁移到了客户端(表单验证等)...

网友评论

      本文标题:高级4:AMD_CMD_RequireJS

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