CommonJS、requirejs勋拟、ES6的對(duì)比

https://blog.csdn.net/crystal6918/article/details/74906757/

CommonJS


?CommonJS就是為JS的表現(xiàn)來(lái)制定規(guī)范勋磕,因?yàn)閖s沒(méi)有模塊的功能所以CommonJS應(yīng)運(yùn)而生,它希望js可以在任何地方運(yùn)行敢靡,不只是瀏覽器中挂滓。

CommonJS是nodejs也就是服務(wù)器端廣泛使用的模塊化機(jī)制。?

該規(guī)范的主要內(nèi)容是啸胧,模塊必須通過(guò)module.exports 導(dǎo)出對(duì)外的變量或接口赶站,通過(guò) require() 來(lái)導(dǎo)入其他模塊的輸出到當(dāng)前模塊作用域中。

根據(jù)這個(gè)規(guī)范纺念,每個(gè)文件就是一個(gè)模塊贝椿,有自己的作用域,文件中的變量陷谱、函數(shù)烙博、類(lèi)等都是對(duì)其他文件不可見(jiàn)的。

如果想在多個(gè)文件分享變量,必須定義為global對(duì)象的屬性渣窜。(不推薦)

定義模塊

在每個(gè)模塊內(nèi)部铺根,module變量代表當(dāng)前模塊。它的exports屬性是對(duì)外的接口乔宿,將模塊的接口暴露出去夷都。其他文件加載該模塊,實(shí)際上就是讀取module.exports變量予颤。

var x =5;

varaddX =function(value) {returnvalue + x;};

module.exports.x = x;

module.exports.addX = addX;? ? ? ? ? ? ?

定義模塊

require方法用于加載模塊囤官,后綴名默認(rèn)為.js

varapp =require('./app.js');

根據(jù)參數(shù)的不同格式,require命令去不同路徑尋找模塊文件蛤虐。

如果參數(shù)字符串以“/”開(kāi)頭党饮,則表示加載的是一個(gè)位于絕對(duì)路徑的模塊文件。

如果參數(shù)字符串以“./”開(kāi)頭驳庭,則表示加載的是一個(gè)位于相對(duì)路徑的模塊文件

如果參數(shù)字符串不以“./“或”/“開(kāi)頭刑顺,則表示加載的是一個(gè)默認(rèn)提供的核心模塊(node核心模塊,或者通過(guò)全局安裝或局部安裝在node_modules目錄中的模塊)

AMD

AMD(異步模塊定義)是為瀏覽器環(huán)境設(shè)計(jì)的饲常,因?yàn)?CommonJS 模塊系統(tǒng)是同步加載的蹲堂,當(dāng)前瀏覽器環(huán)境還沒(méi)有準(zhǔn)備好同步加載模塊的條件。

requirejs即為遵循AMD規(guī)范的模塊化工具贝淤。?

RequireJS的基本思想是柒竞,通過(guò)define方法,將代碼定義為模塊播聪;通過(guò)require方法朽基,實(shí)現(xiàn)代碼的模塊加載。

ES6 Modules

ES6正式提出了內(nèi)置的模塊化語(yǔ)法离陶,我們?cè)跒g覽器端無(wú)需額外引入requirejs來(lái)進(jìn)行模塊化稼虎。

ES6中的模塊有以下特點(diǎn):

模塊自動(dòng)運(yùn)行在嚴(yán)格模式下

在模塊的頂級(jí)作用域創(chuàng)建的變量,不會(huì)被自動(dòng)添加到共享的全局作用域招刨,它們只會(huì)在模塊頂級(jí)作用域的內(nèi)部存在霎俩;

模塊頂級(jí)作用域的 this 值為 undefined

對(duì)于需要讓模塊外部代碼訪問(wèn)的內(nèi)容,模塊必須導(dǎo)出它們

定義模塊

使用export關(guān)鍵字將任意變量沉眶、函數(shù)或者類(lèi)公開(kāi)給其他模塊打却。

重命名模塊


這里將本地的sum函數(shù)重命名為add導(dǎo)出,因此在使用此模塊的時(shí)候必須使用add這個(gè)名稱(chēng)沦寂。

導(dǎo)出默認(rèn)值

模塊的默認(rèn)值是使用?default 關(guān)鍵字所指定的單個(gè)變量学密、函數(shù)或類(lèi),而你在每個(gè)模塊中只能設(shè)置一個(gè)默認(rèn)導(dǎo)出传藏。


加載模塊


限制export 與 import 都有一個(gè)重要的限制腻暮,那就是它們必須被用在其他語(yǔ)句或表達(dá)式的外部彤守,而不能使用在if等代碼塊內(nèi)部。原因之一是模塊語(yǔ)法需要讓 JS 能靜態(tài)判斷需要導(dǎo)出什么哭靖,正因?yàn)榇司叩妫阒荒茉谀K的頂級(jí)作用域使用 export與import。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末试幽,一起剝皮案震驚了整個(gè)濱河市筝蚕,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌铺坞,老刑警劉巖起宽,帶你破解...
    沈念sama閱讀 218,122評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異济榨,居然都是意外死亡坯沪,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,070評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)擒滑,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)腐晾,“玉大人,你說(shuō)我怎么就攤上這事丐一≡逄牵” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,491評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵库车,是天一觀的道長(zhǎng)巨柒。 經(jīng)常有香客問(wèn)我,道長(zhǎng)凝颇,這世上最難降的妖魔是什么潘拱? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,636評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮拧略,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘瘪弓。我一直安慰自己垫蛆,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,676評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布腺怯。 她就那樣靜靜地躺著袱饭,像睡著了一般。 火紅的嫁衣襯著肌膚如雪呛占。 梳的紋絲不亂的頭發(fā)上虑乖,一...
    開(kāi)封第一講書(shū)人閱讀 51,541評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音晾虑,去河邊找鬼疹味。 笑死仅叫,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的糙捺。 我是一名探鬼主播诫咱,決...
    沈念sama閱讀 40,292評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼洪灯!你這毒婦竟也來(lái)了坎缭?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,211評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤签钩,失蹤者是張志新(化名)和其女友劉穎掏呼,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體铅檩,經(jīng)...
    沈念sama閱讀 45,655評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡憎夷,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,846評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了柠并。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片岭接。...
    茶點(diǎn)故事閱讀 39,965評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖臼予,靈堂內(nèi)的尸體忽然破棺而出鸣戴,到底是詐尸還是另有隱情,我是刑警寧澤粘拾,帶...
    沈念sama閱讀 35,684評(píng)論 5 347
  • 正文 年R本政府宣布窄锅,位于F島的核電站,受9級(jí)特大地震影響缰雇,放射性物質(zhì)發(fā)生泄漏入偷。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,295評(píng)論 3 329
  • 文/蒙蒙 一械哟、第九天 我趴在偏房一處隱蔽的房頂上張望疏之。 院中可真熱鬧,春花似錦暇咆、人聲如沸锋爪。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,894評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)其骄。三九已至,卻和暖如春扯旷,著一層夾襖步出監(jiān)牢的瞬間拯爽,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,012評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工钧忽, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留毯炮,地道東北人逼肯。 一個(gè)月前我還...
    沈念sama閱讀 48,126評(píng)論 3 370
  • 正文 我出身青樓否副,卻偏偏與公主長(zhǎng)得像汉矿,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子备禀,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,914評(píng)論 2 355

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