AMD_CMD_RequireJS

1.为什么要使用模块化?

解决命名冲突;
可进行依赖管理;
增强代码的可读性;
代码解耦,提高代码的复用率;

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

Commonjs:用于服务器端模块化,有一个全局性方法require(),用于加载模块。定义模块接口使用module.exports对象。著名的应用是Nodejs。commonjs是同步加载,这对服务器端不是一个问题,因为所有的模块都存放在本地硬盘,可以同步加载完成,等待时间就是硬盘的读取时间。

  //模块定义 myModel.js
var name = 'Byron';

function printName(){
  console.log(name);
}

function printFullName(firstName){
  console.log(firstName + name);
}

// 模块输出
module.exports = {
  printName: printName,
  printFullName: printFullName
}

//加载模块
var nameModule = require('./myModel.js');
// 使用模块内的方法
nameModule.printName();

AMD:异步模块定义,浏览器端的模块化开发规范。由于不是JavaScript原生支持,所以使用AMD规范进行页面开发需要用到对应的库函数RequireJS。实际上AMD规范是 RequireJS 在推广过程中总结出的模块定义规范。它采用异步方式加载模块,模块的加载不影响它后面语句的运行。所有依赖这个模块的语句,都定义在一个回调函数中,等到加载完成之后,这个回调函数才会运行。
加载模块requirejs()语法:require([module], callback) 第一个参数[module],是一个数组,里面的成员就是要加载的模块;第二个参数callback,则是加载成功之后的回调函数。
定义模块define()语法:define(id?,[dependencies],factory)第一个参数模块名称(可选),第二个参数当前所定义模块的依赖(可选),第三个参数工厂函数定义模块初始化执行的函数或对象,为函数时仅执行一次,为对象时此对象为模块的输出值。

// 定义模块 myModule.js
define(['dependency'], function(){
  var name = 'Byron';
  function printName(){
    console.log(name);
  }

  return {
    printName: printName
  };
});

// 加载模块
require(['myModule'], function (my){
  my.printName();
});

CMD:通用模块定义,是seajs在推广过程中总结出的模块定义规范。AMD推崇依赖前置。,CMD推崇依赖就近。

// 定义模块  myModule.js
define(function(require, exports, module) {
  var $ = require('jquery.js')
  $('div').addClass('active');
});

// 加载模块
seajs.use(['myModule.js'], function(my){
  doSomething
});

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

1. 首屏大图为全屏轮播
 2. 有回到顶部功能
 3. 图片区使用瀑布流布局(图片高度不一),下部有加载更多按钮,点击加载更多会加载更多数据(数据在后端 mock)
 4.  使用 r.js 打包应用

require

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 为什么要使用模块化? 最主要的目的:解决命名冲突依赖管理 其他价值提高代码可读性代码解耦,提高复用性 CMD、AM...
    Eazer阅读 4,003评论 3 1
  • 题目1: 为什么要使用模块化? 模块的由来:嵌入网页的JS代码越来越庞大,越来越像桌面程序,需要一个团队去分工协作...
    萧雪圣阅读 2,271评论 0 0
  • 题目1:为什么要使用模块化? 最主要的目的:解决命名冲突依赖管理其他价值提高代码可读性代码解耦,提高复用性 在Ja...
    无目的阅读 2,929评论 0 0
  • 最近在做软件从2.3到4.0的改变的一些工作,其中涉及了一些style和theme相关的东西。上网上查了一些东西,...
    Ten_Minutes阅读 4,855评论 0 2

友情链接更多精彩内容