前端模塊化是什么 (不同模塊規(guī)范的異同)

一、簡介

1.什么是模塊化舌稀?

簡單地說聂儒,模塊化就是有組織地把一個(gè)大文件拆成獨(dú)立并互相依賴的多個(gè)小模塊扩所。
模塊內(nèi)部有許多私有屬性围详,只向外暴露一部分公開的接口(如可以修改私有屬性的方法等)

2.為什么要模塊化?

ES6之前祖屏,JavaScript語言一直沒有模塊(module)體系助赞,無法把大文件有組織地劃分成小塊,并管理之間地依賴袁勺。但是模塊化的思想一直存在雹食。因?yàn)橛肑avascript寫的代碼越來越龐大,而網(wǎng)頁也越來越像桌面APP期丰。如此龐雜的代碼群叶,如果不進(jìn)行模塊化,就可能引發(fā)命名沖突钝荡,造成不易復(fù)用街立、維護(hù)性高。

3.模塊劃分

一般埠通,為了清晰明了赎离,一個(gè)文件對(duì)應(yīng)一個(gè)模塊。

二端辱、模塊化規(guī)范

1. CommonJS

Node.js遵循的規(guī)范

const { PI } = Math;
module.exports.getArea = (r) => PI * r * 2; // 向外暴露(計(jì)算圓形的面積的)getArea方法

注意梁剔,這里的module可省略(不推薦)虽画,寫成:

const { PI } = Math
exports.getArea = (r) => PI * r * 2 // 向外暴露(計(jì)算圓形的面積的)getArea方法(省略了module)

特點(diǎn):

1.代碼運(yùn)行在模塊作用域,不會(huì)污染全局
2.加載模塊順序按照詞法解析的順序加載
3.加載模塊是同步的
4.單例加載:也就是加載的模塊會(huì)緩存起來荣病,再次使用時(shí)码撰,會(huì)直接用運(yùn)行結(jié)果,不會(huì)再加載(除非手動(dòng)清除)
5.加載模塊得到的是結(jié)果的拷貝

2. AMD

RequireJS遵循的規(guī)范
AMD用define()定義模塊个盆,用require()加載模塊灸拍。

// 定義一個(gè)新的模塊,這個(gè)新的模塊可能用到a模塊和b模塊
// define第一個(gè)參數(shù)是 依賴模塊的數(shù)組砾省,對(duì)應(yīng)callback里的參數(shù)
define(["a", "b"], function(a, b) {
    // 1. 在最前面加載了a鸡岗、b

    // 2. 使用模塊a
    const a = require('./a')  // a在最前面已經(jīng)加載好了

    // 3.處理其他代碼
    if (false) {
        // 這里實(shí)際上是不可達(dá)代碼(永遠(yuǎn)不會(huì)被執(zhí)行)
        // 所以b實(shí)際不需要加載。然而因?yàn)锳MD是依賴前置编兄、提前執(zhí)行的轩性,
        // 所以b還是會(huì)在最前面被提前加載的
        console.log(b.getArea(1))  // 6.283185307179586
    }
    
    // 向外暴露接口(寫法1)
    const getArea = (r) => PI * r * 2
    return { getArea }

    // 向外暴露接口(寫法2)
    const getArea2 = (r) => PI * r * 2
    exports.getArea2 = getArea2
});

特點(diǎn):

1.加載模塊推崇依賴前置、提前執(zhí)行
2.加載模塊是異步的

3. CMD

sea.js遵循的規(guī)范
CMD也是用define()定義模塊狠鸳,用require()加載模塊揣苏,但思想不同、寫法也不同件舵。
CMD規(guī)范是在sea.js推廣的過程中產(chǎn)生的卸察,寫法如下:

// 定義一個(gè)新的模塊,這個(gè)新的模塊可能用到a模塊和b模塊
// define接收一個(gè)callback參數(shù)铅祸,對(duì)應(yīng)
define(function(require, exports, module) {
    // 最前面不提前加載模塊

    // 1. 使用模塊a
    const a = require('./a')  // 依賴就近坑质、延遲執(zhí)行,需要a临梗,就去require a

    // 2.處理其他代碼

    if(false) {
      // 這里實(shí)際上是不可達(dá)代碼(永遠(yuǎn)不會(huì)被執(zhí)行)
      // 所以b實(shí)際不需要加載涡扼。恰好CMD是依賴就近、延遲執(zhí)行的盟庞,
      // 所以b的確是不會(huì)被加載的
      const b = require('./b')

      // 處理其他代碼
    }
    
    // 向外暴露接口(寫法1)
    const getArea = (r) => PI * r * 2
    return { getArea }

    // 向外暴露接口(寫法2)
    const getArea2 = (r) => PI * r * 2
    exports.getArea2 = getArea2
})

// 使用的地方:
seajs.use(['a.js'], function(a){ // 依賴就近吃沪,需要a,就去require a
    console.log(a.getArea(1))  // 6.283185307179586
})

特點(diǎn):

1.加載模塊推崇依賴就近什猖、延遲執(zhí)行
2.加載模塊也是異步的

4. ES6 模塊

ES6 模塊的設(shè)計(jì)思想是盡量的靜態(tài)化票彪,使得編譯時(shí)就能確定模塊的依賴關(guān)系

// a.js
const getArea = (r) => PI * r * 2
export { getArea }  // 向外暴露一個(gè)對(duì)象,對(duì)象有一個(gè)(計(jì)算圓形的面積的)方法getArea

// 使用的地方:
import { getArea } = './a.js' // 注意這里拿到的是一個(gè)對(duì)象不狮,對(duì)象里有g(shù)etArea方法
console.log(getArea(1))  // 6.283185307179586

ES6還提供了一個(gè)default降铸,用來提供默認(rèn)的export:

// a.js
const getArea = (r) => PI * r * 2
export default getArea // 向外直接暴露一個(gè)(計(jì)算圓形的面積的)方法getArea

// 用的地方:
import getArea = './a.js'  // 注意這里拿到的就是getArea方法
console.log(getArea(1))  // 6.283185307179586

特點(diǎn):

1.編譯時(shí)確定模塊的依賴關(guān)系
2.加載模塊存儲(chǔ)的是值的引用,所以全局只有一份
3.加載模塊也是異步的

三荤傲、總結(jié)

最開始垮耳,JavaScript沒有模塊。后來:

有CommoneJS規(guī)范,最典型的實(shí)踐就是Node.js终佛,主要使用在服務(wù)器端俊嗽,同步加載模塊;

有AMD铃彰,最典型的實(shí)踐就是RequireJS绍豁,依賴前置,主要使用在瀏覽器端牙捉,異步加載模塊竹揍。

有CMD,最典型的實(shí)踐就是sea.js邪铲,依賴就近芬位,主要使用在瀏覽器端,異步加載模塊带到。

有ES6的Module昧碉,在語言層面定義了模塊,通過export和import揽惹,吸收了CommoneJS和AMD兩者的優(yōu)點(diǎn)被饿,兼容兩標(biāo)準(zhǔn)的規(guī)范

四、推薦文章:

Node.js Nodule
RequireJS-定義模塊
Sea.js-定義模塊
ES6 Module 的語法-阮一峰

(完)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末搪搏,一起剝皮案震驚了整個(gè)濱河市狭握,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌疯溺,老刑警劉巖论颅,帶你破解...
    沈念sama閱讀 222,104評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異喝检,居然都是意外死亡嗅辣,警方通過查閱死者的電腦和手機(jī)撼泛,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,816評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門挠说,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人愿题,你說我怎么就攤上這事损俭。” “怎么了潘酗?”我有些...
    開封第一講書人閱讀 168,697評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵杆兵,是天一觀的道長。 經(jīng)常有香客問我仔夺,道長琐脏,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,836評(píng)論 1 298
  • 正文 為了忘掉前任,我火速辦了婚禮日裙,結(jié)果婚禮上吹艇,老公的妹妹穿的比我還像新娘。我一直安慰自己昂拂,他們只是感情好受神,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,851評(píng)論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著格侯,像睡著了一般鼻听。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上联四,一...
    開封第一講書人閱讀 52,441評(píng)論 1 310
  • 那天撑碴,我揣著相機(jī)與錄音,去河邊找鬼朝墩。 笑死灰羽,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的鱼辙。 我是一名探鬼主播廉嚼,決...
    沈念sama閱讀 40,992評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼倒戏!你這毒婦竟也來了怠噪?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,899評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤杜跷,失蹤者是張志新(化名)和其女友劉穎傍念,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體葛闷,經(jīng)...
    沈念sama閱讀 46,457評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡憋槐,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,529評(píng)論 3 341
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了淑趾。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片阳仔。...
    茶點(diǎn)故事閱讀 40,664評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖扣泊,靈堂內(nèi)的尸體忽然破棺而出近范,到底是詐尸還是另有隱情,我是刑警寧澤延蟹,帶...
    沈念sama閱讀 36,346評(píng)論 5 350
  • 正文 年R本政府宣布评矩,位于F島的核電站,受9級(jí)特大地震影響阱飘,放射性物質(zhì)發(fā)生泄漏斥杜。R本人自食惡果不足惜虱颗,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,025評(píng)論 3 334
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望蔗喂。 院中可真熱鬧上枕,春花似錦、人聲如沸弱恒。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,511評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽返弹。三九已至锈玉,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間义起,已是汗流浹背拉背。 一陣腳步聲響...
    開封第一講書人閱讀 33,611評(píng)論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留默终,地道東北人椅棺。 一個(gè)月前我還...
    沈念sama閱讀 49,081評(píng)論 3 377
  • 正文 我出身青樓,卻偏偏與公主長得像齐蔽,于是被迫代替她去往敵國和親两疚。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,675評(píng)論 2 359

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

  • 前言在 JavaScript 發(fā)展初期就是為了實(shí)現(xiàn)簡單的頁面交互邏輯含滴,寥寥數(shù)語即可诱渤;如今 CPU、瀏覽器性能得到了...
    前端一菜鳥閱讀 837評(píng)論 0 9
  • Javascript模塊化編程祝闻,已經(jīng)成為一個(gè)迫切的需求占卧。理想情況下,開發(fā)者只需要實(shí)現(xiàn)核心的業(yè)務(wù)邏輯治筒,其他都可以加載...
    zhoulujun閱讀 2,941評(píng)論 0 14
  • 1. 前言 現(xiàn)在的前端開發(fā), 通常是一個(gè)單頁面應(yīng)用屉栓,每一個(gè)視圖通過異步的方式加載,這導(dǎo)致頁面初始化和使用過程中會(huì)加...
    majun00閱讀 729評(píng)論 0 2
  • 最近是我每月固定的迷茫期牲平,因?yàn)槲也恢雷约旱降自撨x擇哪條路比較合適堤框。 半永久的生意顯見著比去年好很多,養(yǎng)活我自己不...
    亦如是閱讀 397評(píng)論 0 0
  • 2015年3月12日 晴 昨天我去買了一條泰迪狗。 它...
    一片常青藤葉閱讀 178評(píng)論 0 0