亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > JavaScript > 正文

根據配置文件加載js依賴模塊

2024-05-06 16:13:11
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了根據配置文件加載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"));
 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩在线免费视频观看| 日韩欧中文字幕| 精品国偷自产在线| 欧美精品性视频| 精品国产91乱高清在线观看| 国内精久久久久久久久久人| 亚洲男人天堂2024| 日韩精品视频在线免费观看| 日韩中文字幕在线观看| 555www成人网| 2019中文字幕全在线观看| 精品美女国产在线| 91夜夜未满十八勿入爽爽影院| 久久精品99久久久香蕉| 日本久久久久久久久久久| 久热精品视频在线观看| 免费91在线视频| 久久av资源网站| 国产成人福利视频| 亚洲视频在线免费观看| 久久综合伊人77777蜜臀| 欧美最近摘花xxxx摘花| 欧美日韩免费观看中文| 91日韩在线播放| 国产精品视频色| 91青草视频久久| 97免费在线视频| 久久久久九九九九| 国产精品毛片a∨一区二区三区|国| 欧美极品少妇全裸体| 亚洲激情小视频| 精品久久久久人成| 538国产精品视频一区二区| 色噜噜狠狠狠综合曰曰曰88av| 中文字幕欧美日韩在线| 亚洲开心激情网| 亚洲精品第一国产综合精品| 91精品久久久久久久久不口人| 亚洲人成在线播放| 欧美成人中文字幕| 亚洲第一区第二区| 亚洲精品自产拍| 亚洲精品国产综合区久久久久久久| 欧美在线国产精品| 中文字幕不卡av| 亚洲精品99久久久久中文字幕| 欧美大秀在线观看| 国产精品久久久久久av下载红粉| 久久香蕉精品香蕉| 亚洲三级免费看| 国产精品扒开腿做爽爽爽男男| 国产欧美亚洲视频| 欧美成年人视频网站欧美| 成人黄色在线观看| 欧美激情a∨在线视频播放| 理论片在线不卡免费观看| 亚洲伊人成综合成人网| 日本一本a高清免费不卡| 日韩毛片在线看| 国产国语刺激对白av不卡| 青青草原一区二区| 亚洲激情视频在线播放| 亚洲一区二区少妇| 国产一级揄自揄精品视频| 日韩欧美在线免费观看| 亚洲精品在线视频| 69久久夜色精品国产69乱青草| 欧美激情xxxx| 91亚洲午夜在线| 国产日韩精品在线播放| 国产a级全部精品| 久久久亚洲影院| 亚洲电影在线看| 在线观看国产精品91| 青草青草久热精品视频在线观看| 日韩精品极品毛片系列视频| 日韩欧美综合在线视频| 精品国产精品三级精品av网址| 精品福利在线看| 亚洲成人av资源网| 欧美性受xxxx黑人猛交| 欧美大片在线看| 日本午夜在线亚洲.国产| 97在线视频免费观看| 自拍偷拍亚洲在线| 青青草精品毛片| 亚洲午夜久久久影院| 国产一区av在线| 日本一区二区不卡| 精品久久在线播放| 91精品国产91久久久久久久久| 日本久久久久久久久久久| 欧美精品久久久久久久久| 国产精品1234| 精品香蕉一区二区三区| 色www亚洲国产张柏芝| 欧美日韩亚洲天堂| 日韩av网站电影| 在线视频一区二区| 深夜福利国产精品| 国产精品精品国产| 国内精品久久久久久中文字幕| 欧美激情视频一区| 国产亚洲精品一区二555| 日韩中文字幕在线看| 亚洲欧美色婷婷| 精品成人国产在线观看男人呻吟| 青青久久av北条麻妃黑人| 国产精品一久久香蕉国产线看观看| 日韩av在线电影网| 久久久在线免费观看| 国产男女猛烈无遮挡91| 国产成人av网| 亚洲免费人成在线视频观看| 亚洲福利在线视频| 国产亚洲精品va在线观看| 欧美香蕉大胸在线视频观看| 久热爱精品视频线路一| 久久视频国产精品免费视频在线| www.亚洲一二| 日韩精品视频观看| 国产精品久久一区主播| 亚洲国产精品va在线看黑人动漫| 美女福利精品视频| 欧美日韩国产黄| 亚洲а∨天堂久久精品喷水| 国产精品扒开腿做爽爽爽视频| 超薄丝袜一区二区| 欧美理论电影网| 岛国av一区二区三区| 日韩三级影视基地| 美女久久久久久久久久久| 992tv成人免费视频| 久久成人综合视频| 亚洲四色影视在线观看| 久久久久久久久久av| 亚洲欧洲国产伦综合| 4k岛国日韩精品**专区| 97激碰免费视频| 中文字幕av一区中文字幕天堂| 狠狠躁夜夜躁人人躁婷婷91| 97国产在线观看| 亚洲一区av在线播放| 91精品美女在线| 性欧美激情精品| 欧美一级淫片aaaaaaa视频| 免费91在线视频| 欧美亚洲成人xxx| 亚洲精品国产suv| 亚洲精品一区二区在线| 美日韩精品视频免费看| 精品国产乱码久久久久久虫虫漫画| 国产精品久久久久久婷婷天堂| 欧美激情精品久久久久久大尺度| 精品自在线视频| 国内精品一区二区三区四区| 日韩成人中文字幕在线观看| 欧美成人精品在线观看| 欧美日韩国产成人高清视频| 成人在线国产精品| 91黑丝高跟在线| 成人激情在线观看| 欧美精品在线网站| 亚洲美女av网站|