欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用requirejs模塊化開發(fā)多頁面一個入口js的使用方式

 更新時間:2017年06月14日 10:56:27   作者:風雨后見彩虹  
這篇文章主要介紹了使用requirejs模塊化開發(fā)多頁面一個入口js的使用方式,需要的朋友可以參考下

描述

知道requirejs的都知道,每一個頁面需要進行模塊化開發(fā)都得有一個入口js文件進行模塊配置。但是現(xiàn)在就有一個很尷尬的問題,如果頁面很多的話,那么這個data-main對應的入口文件就會很多。理論這樣其實也沒什么,但是到后面用grunt進行合并壓縮就會有很多入口js,雖然這個入口js都把配置的模塊內(nèi)容都壓縮到里面了,但是各個入口合并壓縮后的文件中其實都有很多重合的代碼,所以考慮到這個就想到把所以的入口文件都統(tǒng)一了,使用一個,到時候用grunt合并壓縮也只有這么一個入口文件,也很方便。

實現(xiàn)原理

1.頁面引入requirejs 和 設置id和當前頁面信息的屬性

<script src="/res/js/require.js" data-main="/res/js/require.config" id="current-page" current-page ="news" target-module="/res/js/module/newsCtrl" defer async="true" ></script>

2、編寫require.config.js 根據(jù)不同的頁面去初始化不同的頁面信息

/** * 1、所有頁面使用公共的require配置
 * 2、根據(jù)current-page去加載相應地模塊,不需要的模塊不要去加載
 * 3、每個模塊都要按約定去對外暴露一個init的初始化方法,用于頁面信息加載時間監(jiān)聽
 * 
 */
require.config({ 
  urlArgs: "ver=1.0_" + (new Date).getTime(),   
  paths: {      
    "jquery": "/res/js/base/jquery-1.11.3.min",
    "vue":'/res/js/base/vue.min',
    "common": "/res/js/widgets/common"
  },
  shim: {
    'scroll': {      
      deps: ['jquery'],
      exports: 'jQuery.fn.scroll'    
    },
    'vue':{
      exports:'vue'
    },
    'common':['jquery']
  }
});
require(["jquery"], function ($) {
  require(["common"], function (common) {
    var currentPage = $("#current-page").attr("current-page");
    var targetModule = $("#current-page").attr("target-module");
    if (targetModule) {
      // 頁面加載完畢后再執(zhí)行相關業(yè)務代碼比較穩(wěn)妥
      $(function () {
        require([targetModule], function (targetModule) {
          // 不要在這里寫業(yè)務代碼
          //全部統(tǒng)一調(diào)用init方法
          //也就是每個模塊都暴露一個init方法用于事件監(jiān)聽,頁面內(nèi)容加載等
          targetModule.init(currentPage);
        });
      });
      return;
    }
  });
});

3、定義模塊,實現(xiàn)初始化init方法進行事件監(jiān)聽和頁面信息初始化

define(['jquery', "common"], function ($, common) {    
  var newCtrl = {};
  newCtrl.init = function (page) {
    common.info("開始初始化頁面信息");
  };
  newCtrl.login = function () {};
  return newCtrl;
});

以上所述是小編給大家介紹的使用requirejs模塊化開發(fā)多頁面一個入口js的使用方式,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關文章

  • Bootstrap列表組學習使用

    Bootstrap列表組學習使用

    這篇文章主要為大家詳細介紹了Bootstrap列表組的學習使用,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • JavaScript ES 模塊的使用

    JavaScript ES 模塊的使用

    這篇文章主要介紹了JavaScript ES 模塊的使用,幫助大家更好的理解和使用JavaScript,感興趣的朋友可以了解下
    2020-11-11
  • javascript正則表達式之search()用法實例

    javascript正則表達式之search()用法實例

    這篇文章主要介紹了javascript正則表達式之search()用法,實例分析了search()的使用技巧,需要的朋友可以參考下
    2015-01-01
  • JS如何定義用字符串拼接的變量

    JS如何定義用字符串拼接的變量

    這篇文章主要介紹了JS如何定義用字符串拼接的變量,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-07-07
  • JS幻想 讀取二進制文件

    JS幻想 讀取二進制文件

    如果說讓JavaScript讀取站點上一文本文件,那不過是個再簡單不了的事了;但若說要換成一個二進制的文件,并且是完全靜態(tài)的讀取,那似乎有點天方夜譚了。
    2009-04-04
  • 用javascript實現(xiàn)畫板的代碼

    用javascript實現(xiàn)畫板的代碼

    用javascript實現(xiàn)畫板的代碼...
    2007-09-09
  • 原生JS實現(xiàn)加載進度條

    原生JS實現(xiàn)加載進度條

    這篇文章主要為大家詳細介紹了原生JS實現(xiàn)加載進度條,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • 理解JavaScript的prototype屬性

    理解JavaScript的prototype屬性

    JavaScript可以說是最讓人初學者難以理解的單一屬性。我看了一些資料后,開始明白其實這些困難很大程度來自prototype這個名字本身的二義性
    2012-02-02
  • 原生js實現(xiàn)隨機點餐效果

    原生js實現(xiàn)隨機點餐效果

    一款十分簡單的原生js實現(xiàn)的隨機點菜代碼,點擊點菜按鈕隨機點取上面菜單的菜品,可根據(jù)需求改成自己需要功能,比如說隨機點名。感興趣的朋友來參考實現(xiàn)代碼吧
    2019-12-12
  • BootstrapValidator不觸發(fā)校驗的實現(xiàn)代碼

    BootstrapValidator不觸發(fā)校驗的實現(xiàn)代碼

    BootstrapValidator是基于bootstrap3的jquery表單驗證插件,是最適合bootstrap框架的表單驗證插件,本文給大家介紹BootstrapValidator不觸發(fā)校驗的實現(xiàn)代碼,感興趣的朋友一起看看吧
    2016-09-09

最新評論