各個(gè)模塊加載的優(yōu)缺點(diǎn)

<script>標(biāo)簽

<script src="module1.js"></script>
<script src="module2.js"></script>
<script src="libraryA.js"></script>
<script src="module3.js"></script>

????這是最原始的 JavaScript 文件加載方式竹挡,如果把每一個(gè)文件看做是一個(gè)模塊,那么他們的接口通常是暴露在全局作用域下,也就是定義在 window對(duì)象中,不同模塊的接口調(diào)用都是一個(gè)作用域中,一些復(fù)雜的框架录语,會(huì)使用命名空間的概念來(lái)組織這些模塊的接口,典型的例子如 YUI 庫(kù)禾乘。

這種原始的加載方式暴露了一些顯而易見(jiàn)的弊端:

????全局作用域下容易造成變量沖突澎埠;
????文件只能按照 <script>的書(shū)寫(xiě)順序進(jìn)行加載;
????開(kāi)發(fā)人員必須主觀解決模塊和代碼庫(kù)的依賴關(guān)系始藕;
????在大型項(xiàng)目中各種資源難以管理蒲稳,長(zhǎng)期積累的問(wèn)題導(dǎo)致代碼庫(kù)混亂不堪。

CommonJS

????服務(wù)器端的 Node.js 遵循 CommonJS規(guī)范伍派,該規(guī)范的核心思想是允許模塊通過(guò) require
方法來(lái)同步加載所要依賴的其他模塊江耀,然后通過(guò) exports或 module.exports來(lái)導(dǎo)出需要暴露的接口。
require("module");require("../file.js");exports.doStuff = function() {};module.exports = someValue;

優(yōu)點(diǎn):

????服務(wù)器端模塊便于重用NPM 中已經(jīng)有將近20萬(wàn)個(gè)可以使用模塊包簡(jiǎn)單并容易使用

缺點(diǎn):

????同步的模塊加載方式不適合在瀏覽器環(huán)境中诉植,同步意味著阻塞加載祥国,瀏覽器資源是異步加載的不能非阻塞的并行加載多個(gè)模塊

實(shí)現(xiàn):
服務(wù)器端的 Node.js
Browserify,瀏覽器端的 CommonJS 實(shí)現(xiàn)晾腔,可以使用 NPM 的模塊舌稀,但是編譯打包后的文件體積可能很大
modules-webmake,類(lèi)似Browserify建车,還不如 Browserify 靈活
wreq扩借,Browserify 的前身

AMD

????Asynchronous Module Definition 規(guī)范其實(shí)只有一個(gè)主要接口 define(id?, dependencies?, factory)椒惨,它要在聲明模塊的時(shí)候指定所有的依賴 dependencies缤至,并且還要當(dāng)做形參傳到 factory中,對(duì)于依賴的模塊提前執(zhí)行,依賴前置领斥。
define("module", ["dep1", "dep2"], function(d1, d2) `{ return someExportedValue;});require(["module", "../file"], function(module, file) { /* ... */ });`

優(yōu)點(diǎn):

適合在瀏覽器環(huán)境中異步加載模塊
可以并行加載多個(gè)模塊

缺點(diǎn):

提高了開(kāi)發(fā)成本嫉到,代碼的閱讀和書(shū)寫(xiě)比較困難,模塊定義方式的語(yǔ)義不順暢
不符合通用的模塊化思維方式月洛,是一種妥協(xié)的實(shí)現(xiàn)

實(shí)現(xiàn):
RequireJS
curl

CMD

Common Module Definition 規(guī)范和 AMD 很相似何恶,盡量保持簡(jiǎn)單,并與 CommonJS 和 Node.js 的 Modules 規(guī)范保持了很大的兼容性嚼黔。
define(function(require, exports, module) { var $ = require('jquery'); var Spinning = require('./spinning'); exports.doSomething = ... module.exports = ...})

優(yōu)點(diǎn):

依賴就近细层,延遲執(zhí)行
可以很容易在 Node.js 中運(yùn)行

缺點(diǎn):

依賴 SPM 打包,模塊的加載邏輯偏重

實(shí)現(xiàn):
Sea.js
coolie

UMD

Universal Module Definition 規(guī)范類(lèi)似于兼容 CommonJS 和 AMD 的語(yǔ)法糖唬涧,是模塊定義的跨平臺(tái)解決方案疫赎。
ES6 模塊
EcmaScript6 標(biāo)準(zhǔn)增加了 JavaScript 語(yǔ)言層面的模塊體系定義。ES6 模塊的設(shè)計(jì)思想碎节,是盡量的靜態(tài)化捧搞,使得編譯時(shí)就能確定模塊的依賴關(guān)系,以及輸入和輸出的變量狮荔。CommonJS 和 AMD 模塊胎撇,都只能在運(yùn)行時(shí)確定這些東西。
import "jquery";export function doStuff() {}module "localModule" {}

優(yōu)點(diǎn):

容易進(jìn)行靜態(tài)分析
面向未來(lái)的 EcmaScript 標(biāo)準(zhǔn)

缺點(diǎn):

原生瀏覽器端還沒(méi)有實(shí)現(xiàn)該標(biāo)準(zhǔn)
全新的命令字殖氏,新版的 Node.js才支持

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末晚树,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子雅采,更是在濱河造成了極大的恐慌题涨,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,126評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件总滩,死亡現(xiàn)場(chǎng)離奇詭異纲堵,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)闰渔,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,254評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén)席函,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人冈涧,你說(shuō)我怎么就攤上這事惹盼。” “怎么了坪它?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,445評(píng)論 0 341
  • 文/不壞的土叔 我叫張陵昔案,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我愚隧,道長(zhǎng)蒂阱,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,185評(píng)論 1 278
  • 正文 為了忘掉前任,我火速辦了婚禮录煤,結(jié)果婚禮上鳄厌,老公的妹妹穿的比我還像新娘。我一直安慰自己妈踊,他們只是感情好了嚎,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,178評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著廊营,像睡著了一般歪泳。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上露筒,一...
    開(kāi)封第一講書(shū)人閱讀 48,970評(píng)論 1 284
  • 那天夹囚,我揣著相機(jī)與錄音,去河邊找鬼邀窃。 笑死荸哟,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的瞬捕。 我是一名探鬼主播鞍历,決...
    沈念sama閱讀 38,276評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼肪虎!你這毒婦竟也來(lái)了劣砍?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 36,927評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤扇救,失蹤者是張志新(化名)和其女友劉穎刑枝,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體迅腔,經(jīng)...
    沈念sama閱讀 43,400評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡装畅,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,883評(píng)論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了沧烈。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片掠兄。...
    茶點(diǎn)故事閱讀 37,997評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖锌雀,靈堂內(nèi)的尸體忽然破棺而出蚂夕,到底是詐尸還是另有隱情,我是刑警寧澤腋逆,帶...
    沈念sama閱讀 33,646評(píng)論 4 322
  • 正文 年R本政府宣布婿牍,位于F島的核電站,受9級(jí)特大地震影響惩歉,放射性物質(zhì)發(fā)生泄漏等脂。R本人自食惡果不足惜俏蛮,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,213評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望慎菲。 院中可真熱鬧嫁蛇,春花似錦锨并、人聲如沸露该。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,204評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)解幼。三九已至,卻和暖如春包警,著一層夾襖步出監(jiān)牢的瞬間撵摆,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,423評(píng)論 1 260
  • 我被黑心中介騙來(lái)泰國(guó)打工害晦, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留特铝,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,423評(píng)論 2 352
  • 正文 我出身青樓壹瘟,卻偏偏與公主長(zhǎng)得像鲫剿,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子稻轨,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,722評(píng)論 2 345

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

  • 1 Node.js模塊的實(shí)現(xiàn) 之前在網(wǎng)上查閱了許多介紹Node.js的文章,可惜對(duì)于Node.js的模塊機(jī)制大都著...
    zlx_2017閱讀 1,221評(píng)論 0 1
  • 隨著前端業(yè)務(wù)復(fù)雜度的增加,模塊化成為一個(gè)大的趨勢(shì)线欲。而在ES6還未被瀏覽器所支持的情況下明场,commonjs作為ES6...
    吳高亮閱讀 1,052評(píng)論 0 3
  • 什么是模塊化開(kāi)發(fā)? 前端開(kāi)發(fā)中李丰,起初只要在script標(biāo)簽中嵌入幾十上百行代碼就能實(shí)現(xiàn)一些基本的交互效果榕堰,后來(lái)js...
    半世韶華憶闌珊閱讀 650評(píng)論 0 0
  • Node.js是目前非常火熱的技術(shù)嫌套,但是它的誕生經(jīng)歷卻很奇特逆屡。 眾所周知,在Netscape設(shè)計(jì)出JavaScri...
    w_zhuan閱讀 3,607評(píng)論 2 41
  • 2017.3.28 晴 品一杯茶踱讨,分享一個(gè)小故事魏蔗。 有個(gè)老木匠準(zhǔn)備退休,他告訴老板痹筛,說(shuō)要離開(kāi)建筑行業(yè)莺治,回家與妻子兒...
    相愛(ài)相依娟閱讀 348評(píng)論 0 1