zoukankan      html  css  js  c++  java
  • JavaScript模块化思想requireJS的使用

    1. 使用require.js的意义
     
    (1)实现JS文件的异步加载,避免网页因为加载JS文件缓慢造成网页未响应
    (2)管理模块之间的依赖性,便于代码的编写和维护。页面中只需要引入require.js和main.js,其余的js文件全部通过require.js管理。

     
    2. 获取require.js
     
      requireJS中文网:http://www.requirejs.cn/home.html

    3. 使用require.js
    把require.js放入项目的js目录下:

    我们需要在html页面中引入require.js:

    1 <script src="js/require.js" type="text/javascript" charset="utf-8" defer="defer" async="async"></script>

    接下来,在js目录下新建我们的入口js文件,我们把它命名为“main.js”。这个文件就相当于java语言中的main函数,是整个js模块体系的入口,我们在main.js中引用我们需要依赖的js文件。

    在刚刚引入require.js的script标签中添加一行一个data-main属性,并赋值为“js/main”。

    1 <script src="js/require.js" data-main = "js/main" type="text/javascript" charset="utf-8" defer="defer" async="async"></script>

    这个属性的值就是指定main.js文件的路径,可以省略.js后缀。


    4. 如何配置main.js文件
    完成了准备工作,接下来看我们可以在main.js中可以干什么。
    (1)写js
    我们可以直接在main.js中编辑javaScript代码:
    1 // main.js
    2 console.log("main.js被执行");

    (2)引入依赖模块(require()函数)
    - 加入要引入的依赖模块和main.js在同一层目录,可以直接使用模块文件名。
    1 require(['firstModule','secondModule','thirdModule'],function(firstModule,secondModule,thirdModule){
    2     //模块加载完成后执行的回调函数
    3 });
    - 如果我们需要手动配置模块文件路径,使用require.config()方法。
    该方法需要写在main.js文件的头部:
    1 require.config({  // main.js文件的路径是js/main.js
    2     paths:{
    3         "firstModule":"lib/firstModule.js"  // 路径是js/lib/firstModule.js
    4         "secondModule":"lib/secondModule.js"    // 路径是js/lib/secondModule.js
    5         "thirdModule":"lib/thirdModule.js"    // 路径是js/lib/thirdModule.js
    6     }
    7 });

    我们发现这三个依赖的js文件都在js目录下的lib目录下,为了书写简单,我们可以设置“基目录”:

    1 require.config({  // main.js文件的路径是js/main.js
    2     baseUrl:"js/lib",
    3     paths:{
    4         "firstModule":"firstModule.js"  // 路径是js/lib/firstModule.js
    5         "secondModule":"secondModule.js"    // 路径是js/lib/secondModule.js
    6         "thirdModule":"thirdModule.js"    // 路径是js/lib/thirdModule.js
    7     }
    8 });

    我们发现这样写有一个问题,就是依赖几个js模块,就得发送几次js请求,require.js针对这个问题有一个优化工具,可以把多个模块合并在一个文件中,减少js请求。这个等我了解之后再单独说... ...


    5. 接下来,我们看一个完整的使用AMD写法实现的模块加载到调用执行的例子:

    目录结构如下:

     1 /*
     2  * js/lib/dates.js
     3  */
     4 define(function(){
     5     let date = new Date();
     6     let outDate = function(){
     7         console.log(date.getDate());
     8     };
     9     return {
    10         outDate:outDate
    11     };
    12 });
    13 
    14 
    15 
    16 /*
    17  *  js/main.js
    18  */
    19 require(['lib/dates'],function(dates){
    20     dates.outDate();
    21 });

    执行结果:


    6. 如何加载没有使用AMD规范的模块(没有使用define()函数定义)

    方法:使用require.config()方法的shim属性配置。
    以jquery.scroll插件为例演示:
    1 shim:{
    2    "jquery.scroll":{
    3         deps:['jquery'],
    4         exports:'jQuery.fn.scroll'
    5    }
    6 }
    - deps : 是一个数组,表明该模块依赖的模块
    - exports : 表明模块外部调用该模块时的变量名

      

  • 相关阅读:
    【python+selenium】selenium grid(分布式)
    【python】导入自定义模块
    Maven的配置以及IDEA导入本地Maven
    java历史概述
    JVM 内存调优 与 实际案例
    ConcurrentHashMap实现线程安全的原理
    Request.UrlReferrer详解
    等比例缩放生成缩略图
    JavaEE的ajax入门
    javaee三层架构案例--简单学生管理系统
  • 原文地址:https://www.cnblogs.com/enjoymylift/p/6033256.html
Copyright © 2011-2022 走看看