成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

javascript構(gòu)建模塊化開發(fā)過程解析-創(chuàng)新互聯(lián)

在使用 sea.js 、require.js 、 angular 的時候。

創(chuàng)新互聯(lián)于2013年創(chuàng)立,先為葉縣等服務(wù)建站,葉縣等地企業(yè),進行企業(yè)商務(wù)咨詢服務(wù)。為葉縣企業(yè)網(wǎng)站制作PC+手機+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。

我們使用到 define 、 module(require) 的方式,定義模塊,和依賴模塊

下面給出 define 和 module 的簡單實現(xiàn)。 其本質(zhì),就是往一個對象上面添加方法

var F = {};
F.define = function(str,fn){
  var parts = str.split(".");
  var parent = this; // parent 當(dāng)前模塊的父模塊
  var i = len = 0;
  //如果第一個模塊是模塊單體對象,則移除
  if(parts[0] == "F"){
    parts = parts.slice(1);
  }
   
  //屏蔽對 define module 模塊方法重寫
  if(parts[0] == "define" || parts[0] == "module"){
    return ;
  }     
   
  for(len = parts.length; i < len-1; i++){
    //如果父模塊中不存在當(dāng)前模塊
    if(typeof parent[parts[i]] === 'undefined'){
      //聲明當(dāng)前模塊
      parent[parts[i]] = {};
    }
    //緩存下一層父模塊
    parent = parent[parts[i]];
  }
   
  if(fn && parts[i]){
    //如果給定模塊方法,則綁定該模塊的方法,
    parent[parts[i]] = fn();
  }
  return this;
}
 
F.module = function(){
  var args = [].slice.call(arguments);//復(fù)制參數(shù)
  var fn = args.pop(); //獲取回調(diào)
   
  var parts = args[0] && args[0] instanceof Array ? args[0] : args;
   
  //模塊的依賴
  var modules = [];
   
  //模塊的路由
  var modIDs = "";
   
  //依賴模塊的索引
  var i = 0;
   
  var len = parts.length; // 依賴模塊的長度
   
  var parent,j,jlen; //父級模塊,模塊路由層級索引,模塊路由層級長度
   
  while(i < len){
    if(typeof parts[i] == "string"){
      parent = this;
      //解析路由,并且屏蔽掉 F
      modIDs = parts[i].replace(/^F\./,"").split(".");
      //遍歷模塊層級
      for( j = 0,jlen = modIDs.length; j < jlen; j++){
        //迭代 父模塊
        parent = parent[modIDs[j]] || false;
      }
      modules.push(parent); //將模塊添加到依賴列表
    }else{
      //直接將模塊添加到依賴列表
      modules.push(parts[i]);
    }
    //取下一個模塊
    i++;
  }
   
   
  //執(zhí)行回調(diào),將依賴的模塊注入
  fn.apply(null,modules);  
} 
//定義 string 模塊
F.define("string",function(){
  return {
    trim(str){
      return str.replace(/^s+|\s+$/g,"");
    }
  }
});
//定義 string 模塊,的子模塊 sub
F.define("string.sub",function(){
  return {
    low(str){
      return str.toLowerCase();
    }
  }
});
console.log(F);
//使用模塊
F.module(["string","string.sub",document],function(str,strSub,doc){
  console.log(str,strSub,doc)
});

分享標(biāo)題:javascript構(gòu)建模塊化開發(fā)過程解析-創(chuàng)新互聯(lián)
鏈接地址:http://jinyejixie.com/article24/hgdje.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄移動網(wǎng)站建設(shè)、標(biāo)簽優(yōu)化、做網(wǎng)站、App開發(fā)、商城網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都app開發(fā)公司
永川市| 儋州市| 伊金霍洛旗| 疏附县| 班戈县| 盐山县| 永嘉县| 文昌市| 泸西县| 浪卡子县| 周口市| 中江县| 淳化县| 荥经县| 邹城市| 合江县| 丰都县| 兰溪市| 福建省| 山丹县| 夹江县| 长海县| 娄烦县| 赫章县| 蚌埠市| 都兰县| 桐庐县| 霍城县| 上虞市| 峨眉山市| 闸北区| 雅江县| 中西区| 南平市| 长宁县| 通化市| 石城县| 宾阳县| 红河县| 晴隆县| 慈利县|