美文网首页
AMD_CMD_RequireJS

AMD_CMD_RequireJS

作者: 66dong66 | 来源:发表于2017-05-15 11:20 被阅读0次

    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

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