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

你可能感兴趣的:(AMD_CMD_RequireJS)