根據設定檔載入js相依模組,設定檔js依賴

來源:互聯網
上載者:User

根據設定檔載入js相依模組,設定檔js依賴

要求:

根據下面的設定檔
複製代碼 代碼如下:
module=[
{'name':'jquery','src':'/js/lib/jquery-1.8.3.js'},
{'name':'swfobject','src':'/js/utils/swfobject.js'},
{'name':'fancybox','src':'/js/jquery/jquery.fancybox.js','require':['jquery']},
{'name':'uploadify','src':'/js/utils/uploadify.js','require':['swfobject']},
{'name':'jqform','src':'/js/jquery/jquery.form.js','require':['jquery']},
{'name':'register','src':'/js/page/reg.js','require':['jqform']},
{'name':'login','src':'/js/page/login.js','require':['fancybox','jqform']},
{'name':'upload','src':'/js/page/upload.js','require':['fancybox','jqform','uploadify']}
]

寫一個函數

def getfiles(name)

返回 載入某個name指定的頁面,要載入的js檔案清單,有依賴的要先載入

小菜解法

    此題粗看起來很簡單,實則不然。

     痛點在於相依模組的載入時機。假如有這樣的依賴關係:A-B&C、B-C,A模組依賴B模組和C模組,同時B模組又依賴了C模組,總不能讓C載入兩次吧!

     小菜給出的這個解法,只是一個思路,肯定有比這更好的演算法,小菜覺得可以用二叉樹之類的演算法解決,但小菜不會呀~~~

     此演算法沒有考慮循環相依性的情景。

     代碼如下:

複製代碼 代碼如下:
 /**
  * 不考慮循環相依性
  * @type {Function}
  */
 var loadModule = (function(){
     /**
      * 商務邏輯封裝
      * @type {{chainHead: {}, chainCurrent: {}, srcCache: {}, main: main, load: load, findModule: findModule}}
      */
     var logics = {
         chainHead: {},     //鏈表頭
         chainCurrent: {},  //鏈表當前節點
         srcCache: {},      //module src 緩衝
         /**
          * 對外介面
          * @param modules  設定物件
          * @param name  模組名稱
          * @returns {Array} 相依模組列表,按照載入先後順序排列
          */
         main: function(modules, name){
             var nameArray = [],  //模組名稱列表
                 srcArray = [],   //相依模組列表
                 nameStr = "",    //模組名稱字串集
                 repeatRegex = /(^| )([\w]+ ).*\2/,  //模組名稱去重正則
                 i = 0;
             //粗略載入所有相依模組
             this.load(modules, name)
             //構造模組名稱字串集
             this.chainCurrent = this.chainHead;
             while(this.chainCurrent.next){
                 nameArray.push(this.chainCurrent.name);
                 this.chainCurrent = this.chainCurrent.next;
             }
             nameStr = nameArray.join(" ") + " ";  //統一標準,末尾補一個空格
             //相依模組去重
             while(repeatRegex.exec(nameStr)){
                 nameStr = nameStr.replace(repeatRegex, function(g0, g1, g2){
                     return g0.substring(0, (g0.length - g2.length));
                 });
             }
             nameStr = nameStr.substring(0, (nameStr.length - 1));  //去掉補充的多餘空格
             //相依模組名稱轉換為模組路徑
             nameArray = nameStr.split(" ");
             for(i = 0; i < nameArray.length; i++){
                 srcArray.push(this.srcCache[nameArray[i]]);
             }
             return srcArray;
         },
         /**
          * 遞迴載入模組
          * @param modules  設定物件
          * @param name  模組名稱
          */
         load: function(modules, name){
             var node = {},
                 module = this.findModule.call(modules, "name", name),
                 i = 0;
             //判斷模組是否存在
             if(!module){
                 throw Error("相依模組 " + name +" 未找到");
             }
             //構造模組依賴鏈表
             node.name = name;
 //            node.src = module.src;
             this.srcCache[name] = module.src;
             node.next = this.chainHead;
             this.chainHead = node;
             //遞迴依賴
             if(module.require && module.require.length){
                 for(i = 0;i < module.require.length; i++){
                     this.load(modules, module.require[i]);
                 }
             }
         },
         /**
          * 根據指定屬性名稱和屬性值尋找模組
          * @param name  屬性名稱
          * @param value  屬性值
          * @returns {*}
          */
         findModule: function(name, value){
             var array = this,
                 item = {},
                 i = 0;
             //遍曆模組
             for(i = 0; i < array.length; i++){
                 item = array[i];
                 //擷取指定模組
                 if(item && item[name] === value){
                     return item;
                 }
             }
             //找不到返回null
             return null;
         }
     };
     //暴露對外介面
     return function(){
         return logics.main.apply(logics, arguments);
     };
 }());
 /**
  * Test Usecase
  * @type {*[]}
  */
 var modules=[
     {'name':'jquery','src':'/js/lib/jquery-1.8.3.js'},
     {'name':'swfobject','src':'/js/utils/swfobject.js'},
     {'name':'fancybox','src':'/js/jquery/jquery.fancybox.js','require':['jquery']},
     {'name':'uploadify','src':'/js/utils/uploadify.js','require':['swfobject']},
     {'name':'jqform','src':'/js/jquery/jquery.form.js','require':['jquery']},
     {'name':'register','src':'/js/page/reg.js','require':['jqform']},
     {'name':'login','src':'/js/page/login.js','require':['fancybox','jqform']},
     {'name':'upload','src':'/js/page/upload.js','require':['fancybox','jqform','login','uploadify']}
 ];
 console.log(loadModule(modules, "upload"));

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.