JS模塊化規(guī)范

一袒炉、CommonJS

1、規(guī)范

  • 說明

    每一個文件都可以當做一個模塊
    在服務(wù)器端:模塊的加載是運行時同步加載的
    在瀏覽器端:模塊需要提前編譯打包處理。(因為瀏覽器不認識其引入的語法,所以需要事先編譯打包成瀏覽器能夠認識的語法才能夠運行)

  • 基本語法
    暴露模塊:

    module.exports=value
    exports.xxx=value
    暴露的本質(zhì)是exports這個對象现斋。exports原本是一個空對象,通過暴露為其添加新的屬性值亿昏。

    引入模塊:

    require(xxx)
    引入第三方模塊時浑测,xxx為模塊名;引入自定義模塊時赎败,xxx為模塊文件路徑

2秕衙、實現(xiàn)

  • 服務(wù)端實現(xiàn)步驟

    (1)下載安裝node.js

    (2)創(chuàng)建項目結(jié)構(gòu)

    /-modules
      /-module1.js
      /-module2.js
      /-module3.js
    /-app.js
    /-package.json
    

    (3)下載第三方模塊(可選)

    npm install uniq --save

    (4)進行模塊化編碼

  • 瀏覽器端實現(xiàn)步驟

    (1)創(chuàng)建項目結(jié)構(gòu)

    /-js
      /-dist //打包生成文件的目錄
      /-src //源碼所在的目錄
          /-module1.js
          /-module2.js
          /-module3.js
          /-app.js //應用主源文件
    /-index.html
    /-package.json
    

    (2)下載browserify

    先全局安裝:npm install browserify -g

    再局部安裝:npm install browserify --save-dev

    (3)進行模塊化編碼

    (4)打包處理js

    browserify js/src/app.js -o js/dist/build.js
    上面的命令意思是將app.js文件進行編譯,輸出為build.js文件

    (5)頁面引入

    <script src="./js/dist/build.js"></script>

二僵刮、AMD

AMD(Asynchronous Module Definition据忘,異步模塊定義),專門用于瀏覽器端搞糕,模塊的加載是異步的勇吊。

1、基本語法

(1)定義暴露模塊
  • 定義沒有依賴的模塊
    define(function(){
      return 模塊
    })
    
  • 定義有依賴的模塊
    define(["module1","module2"],function(m1,m2){
      return 模塊
    })
    
(2)引入暴露模塊
require(["module1","module2"],function(m1,m2){
    使用m1/m2
})

2窍仰、實現(xiàn)步驟

(1)下載require.js

官網(wǎng):https://requirejs.org/
將require.js引入到項目中:js/libs/require.js

(2)創(chuàng)建目錄結(jié)構(gòu)
/-js
    /-libs
        /-require.js
    /-modules
        /-alerter.js
        /-dataService.js
    /-main.js
/-index.html
(3)定義require.js的模塊代碼

三汉规、CMD

CMD(Common Modules Definition,通用模塊定義)驹吮,專門用于瀏覽器端针史,模塊的加載是異步的,模塊在使用時才會加載碟狞。這種方式在開發(fā)中用的比較少啄枕。

1、基本語法

(1)定義暴露模塊
  • 定義沒有依賴的模塊
    define(function(require,exports,module){
      exports.xxx=value;
      module.exports=value;
    })
    
  • 定義有依賴的模塊
    define(function(require,exports,module){
      //引入依賴模塊(同步)
      var module2=require("./module2");
      //引入依賴模塊(異步)
      require.async("./module3",function(m3){
      
      });
      //暴露模塊
      exports.xxx=value;
    })
    
(2)引入暴露模塊
define(function(require){
    var m1=require("./module1");
    var m2=require("./module2");
    m1.show();
    m2.show();
})

2篷就、實現(xiàn)步驟

(1)下載sea.js并引入

官網(wǎng):https://seajs.github.io/seajs/docs/#intro
將sea.js導入項目:js/libs/sea.js

(2)創(chuàng)建項目模塊

/-js
    /-libs
        /-sea.js
    /-modules
        /-module1.js
        /-module2.js
        /-module3.js
        /-main.js
/-index.html

(3)定義sea.js的模塊代碼

四射亏、ES6

1、創(chuàng)建目錄結(jié)構(gòu)
/-js
    /-src
        /-module1.js
        /-module2.js
        /-module3.js
/-index.html
/-package.json
2竭业、安裝babel-cli, babel-preset-es2015 和 browserify:

第一步:全局安裝 npm install babel-cli browserify -g
(cli: command line interface 命令行接口工具)

第二步:局部安裝 npm install babel-preset-es2015 --save-dev

注:如果已經(jīng)安裝了browserify智润,可以在第一步中去除browserify

3、創(chuàng)建.babelrc文件(給babel指定具體的任務(wù))

文件內(nèi)容如下:

{
    "presets":["es2015"]
}
4未辆、編碼
  • 分別暴露
/*js/src/module1.js*/
export let data="dexter";
export function demo(){
    console.log("我是module1中的demo函數(shù)",data.toLocaleUpperCase());
}
export function test(){
    console.log("我是module2中的test函數(shù)",data.toLocaleLowerCase());
}
  • 統(tǒng)一暴露
/*js/src/module2.js*/
export {demo2,test2}
let arr=[1,2,3,4,5]; //私有數(shù)據(jù)
function demo2(){
    console.log("我是module2中的demo2函數(shù)",arr);
}
function test2(){
    console.log("我是module2中的test2函數(shù)",arr);
}
  • 默認暴露
/*js/src/module3.js*/
export default{
    name:"peiqi",
    age:18,
    speak(){
        console.log("我的名字是${this.name},我的年齡是${this.age}");
    }
}
5窟绷、模塊的引入
  • 分別暴露與統(tǒng)一暴露的引入方式

    import {foo,bar} from "./module1";
    import {fun1,fun2} from "./module2";
    
  • 默認暴露的引入方式

    import module3 from "./module3";
    
  • 第三方模塊引入方式

    import $ from "jquery";
    
6、編譯源代碼

首先要確保已經(jīng)進入ES6-Babel-Browserify所在的文件夾

第一步:使用Babel將ES6編譯為ES5代碼
命令為:babel js/src -d js/build 咐柜,表示編譯src文件夾下的所有js文件兼蜈,保存到build文件中

第二步:使用Browserify編譯js上一步生成的js
命令為:browserify js/build/app.js -o js/build/build.js

注:第一步操作后Babel將es6的模塊化語法轉(zhuǎn)換成了CommonJS模塊化語法(瀏覽器不識別)攘残,因此需要執(zhí)行第二步對進過babel編譯的app.js文件通過browerify進一步編譯才可以執(zhí)行。

7为狸、html文件載入

<script src="./js/build/appbuild.js"></script>

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末歼郭,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子辐棒,更是在濱河造成了極大的恐慌病曾,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,755評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件漾根,死亡現(xiàn)場離奇詭異泰涂,居然都是意外死亡,警方通過查閱死者的電腦和手機辐怕,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評論 3 395
  • 文/潘曉璐 我一進店門逼蒙,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人寄疏,你說我怎么就攤上這事是牢。” “怎么了赁还?”我有些...
    開封第一講書人閱讀 165,138評論 0 355
  • 文/不壞的土叔 我叫張陵妖泄,是天一觀的道長驹沿。 經(jīng)常有香客問我艘策,道長,這世上最難降的妖魔是什么渊季? 我笑而不...
    開封第一講書人閱讀 58,791評論 1 295
  • 正文 為了忘掉前任朋蔫,我火速辦了婚禮,結(jié)果婚禮上却汉,老公的妹妹穿的比我還像新娘驯妄。我一直安慰自己,他們只是感情好合砂,可當我...
    茶點故事閱讀 67,794評論 6 392
  • 文/花漫 我一把揭開白布青扔。 她就那樣靜靜地躺著,像睡著了一般翩伪。 火紅的嫁衣襯著肌膚如雪微猖。 梳的紋絲不亂的頭發(fā)上缘屹,一...
    開封第一講書人閱讀 51,631評論 1 305
  • 那天凛剥,我揣著相機與錄音,去河邊找鬼轻姿。 笑死犁珠,一個胖子當著我的面吹牛逻炊,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播犁享,決...
    沈念sama閱讀 40,362評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼余素,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了炊昆?” 一聲冷哼從身側(cè)響起溺森,我...
    開封第一講書人閱讀 39,264評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎窑眯,沒想到半個月后屏积,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,724評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡磅甩,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,900評論 3 336
  • 正文 我和宋清朗相戀三年炊林,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片卷要。...
    茶點故事閱讀 40,040評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡渣聚,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出僧叉,到底是詐尸還是另有隱情奕枝,我是刑警寧澤,帶...
    沈念sama閱讀 35,742評論 5 346
  • 正文 年R本政府宣布瓶堕,位于F島的核電站隘道,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏郎笆。R本人自食惡果不足惜谭梗,卻給世界環(huán)境...
    茶點故事閱讀 41,364評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望宛蚓。 院中可真熱鬧激捏,春花似錦、人聲如沸凄吏。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,944評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽痕钢。三九已至图柏,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間盖喷,已是汗流浹背爆办。 一陣腳步聲響...
    開封第一講書人閱讀 33,060評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留课梳,地道東北人距辆。 一個月前我還...
    沈念sama閱讀 48,247評論 3 371
  • 正文 我出身青樓余佃,卻偏偏與公主長得像,于是被迫代替她去往敵國和親跨算。 傳聞我的和親對象是個殘疾皇子爆土,可洞房花燭夜當晚...
    茶點故事閱讀 44,979評論 2 355

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