AMD_CMD_RequireJS

1: 為什么要使用模塊化浮创?

網(wǎng)頁越來越復雜斩披,js代碼越來越多讹俊,在多人協(xié)作下如何管理代碼?于是就有了模塊化厕倍。

  • 解決命名沖突贩疙;
  • 方便依賴性管理;
  • 提高代碼的維護性和可讀性组民;
  • 代碼解耦悲靴,提高代碼復用性;
2: CMD耸三、AMD浇揩、CommonJS 規(guī)范分別指什么?有哪些應(yīng)用
  • AMD
    可以異步加載模塊胳徽,并且會提前加載依賴膜廊。
define("alpha", ["require", "exports", "beta"], function (require, exports, beta) {
   //模塊代碼
  return 模塊名
});

有三個參數(shù)淫茵,分別是:本模塊的名字、依賴模塊數(shù)組铆铆、依賴模塊傳入使用。

  • CommonJS
    使用require方法加載模塊翁都,通過module.exports來導出接口谅猾。Node.js采用這個規(guī)范。
//myModel.js
function printName(){
    console.log(name);
}
module.exports = { // 導出接口
    printName: printName,
}
//加載模塊
var nameModule = require('./myModel.js');
nameModule.printName(); //myModel.js里的方法

加載模塊是同步的坐搔,只有加載完成后才能執(zhí)行后面的操作敬矩。

  • CMD
    就近加載依賴弧岳。
define(function(require, exports, module) {
  // 模塊代碼
  });
  • AMD與CMD的區(qū)別:
    AMD推崇依賴前置,在定義模塊的時候就要聲明其依賴的模塊涧卵。
    CMD推崇就近依賴瞎抛,只有在用到某個模塊的時候再去require。
  //AMD  必須一開始就聲明依賴模塊
  define("alpha", ["require", "exports", "beta"], function (require, exports, beta) {
      //模塊代碼
   });

 //CMD
 define(function(require, exports, module) {
     // 模塊代碼
     //100行代碼后胎撤,需要某個模塊断凶。
     var alpha = require('./alpha') //就近加載
   });
3.requirejs的使用
- www/
 - index.html
 - js/
     app/ 頁面的js模塊
      sub.js
   - lib/  第三方庫 如jq
     jquery.js
    canvas.js
  - app.js 頁面入口配置文件

在index.html中:

<script data-main="js/app.js" src="js/require.js"></script>
先加載require.js完成后,然后再加載app.js頁面入口配置文件
requirejs.config({
   
    baseUrl: 'js/lib',  基本路徑
 
    paths: {   路徑縮寫
        app: '../app'
    }
});
require(app/index.js)

詳細的使用可以直接參考 requirejs文檔肿男,包括使用r.js打包壓縮却嗡。

在r.js中窗价,mian.js路徑是相對于index.html,而build.js是相對于自己的位置坪它,所以在寫 baseUrl有所不同。

4: 使用 requirejs 完善入門任務(wù)15往毡,包括如下功能:

Paste_Image.png

實戰(zhàn)task15-2

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末懒震,一起剝皮案震驚了整個濱河市惩阶,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌锨匆,老刑警劉巖冬筒,帶你破解...
    沈念sama閱讀 221,273評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件舞痰,死亡現(xiàn)場離奇詭異,居然都是意外死亡玷禽,警方通過查閱死者的電腦和手機呀打,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,349評論 3 398
  • 文/潘曉璐 我一進店門贬丛,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人豺憔,你說我怎么就攤上這事恭应。” “怎么了境肾?”我有些...
    開封第一講書人閱讀 167,709評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我莺掠,道長,這世上最難降的妖魔是什么楔绞? 我笑而不...
    開封第一講書人閱讀 59,520評論 1 296
  • 正文 為了忘掉前任酒朵,我火速辦了婚禮扎附,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘匙铡。我一直安慰自己碍粥,他們只是感情好,可當我...
    茶點故事閱讀 68,515評論 6 397
  • 文/花漫 我一把揭開白布钦讳。 她就那樣靜靜地躺著愿卒,像睡著了一般。 火紅的嫁衣襯著肌膚如雪膊畴。 梳的紋絲不亂的頭發(fā)上掘猿,一...
    開封第一講書人閱讀 52,158評論 1 308
  • 那天,我揣著相機與錄音唇跨,去河邊找鬼稠通。 笑死,一個胖子當著我的面吹牛买猖,可吹牛的內(nèi)容都是我干的改橘。 我是一名探鬼主播,決...
    沈念sama閱讀 40,755評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼玉控,長吁一口氣:“原來是場噩夢啊……” “哼飞主!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,660評論 0 276
  • 序言:老撾萬榮一對情侶失蹤碌识,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后筏餐,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體开泽,經(jīng)...
    沈念sama閱讀 46,203評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,287評論 3 340
  • 正文 我和宋清朗相戀三年魁瞪,在試婚紗的時候發(fā)現(xiàn)自己被綠了穆律。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,427評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡导俘,死狀恐怖峦耘,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情旅薄,我是刑警寧澤辅髓,帶...
    沈念sama閱讀 36,122評論 5 349
  • 正文 年R本政府宣布,位于F島的核電站少梁,受9級特大地震影響利朵,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜猎莲,卻給世界環(huán)境...
    茶點故事閱讀 41,801評論 3 333
  • 文/蒙蒙 一绍弟、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧著洼,春花似錦樟遣、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,272評論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至液荸,卻和暖如春瞻佛,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背娇钱。 一陣腳步聲響...
    開封第一講書人閱讀 33,393評論 1 272
  • 我被黑心中介騙來泰國打工伤柄, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人文搂。 一個月前我還...
    沈念sama閱讀 48,808評論 3 376
  • 正文 我出身青樓适刀,卻偏偏與公主長得像,于是被迫代替她去往敵國和親煤蹭。 傳聞我的和親對象是個殘疾皇子笔喉,可洞房花燭夜當晚...
    茶點故事閱讀 45,440評論 2 359

推薦閱讀更多精彩內(nèi)容