理解模塊化

在理解模塊化的前提细层,我們要先弄明白什么是模塊腊嗡?

所謂的模塊,在變成中直白的說(shuō)域蜗,就是我們要將一個(gè)復(fù)雜的程序依據(jù)一定的規(guī)則或者說(shuō)規(guī)范封裝成幾個(gè)快(文件)缘屹,并將它們進(jìn)行組合在一起

快的內(nèi)部數(shù)據(jù)/實(shí)現(xiàn)? ? ?是私有的凛剥,我們只是向外暴露一些接口,讓其與外部其他的模塊進(jìn)行通信轻姿。

那么一個(gè)模塊的組成由那些部分呢犁珠?

首先是數(shù)據(jù)逻炊,我們?cè)诮M成模塊的時(shí)候必定要有數(shù)據(jù)為依據(jù)的,數(shù)據(jù)就是模塊的內(nèi)部屬性犁享,我們姑且可以這么認(rèn)為余素,而我們是通過(guò)什么來(lái)操作數(shù)據(jù)的呢?我們操作數(shù)據(jù)炊昆,也就是它的內(nèi)部屬性時(shí)通過(guò)它里面的函數(shù)來(lái)操作的桨吊。

在模塊化的定義中,我們必須要明白的是凤巨,我們將項(xiàng)目模塊化之后视乐,整個(gè)項(xiàng)目也就是一個(gè)模塊化的項(xiàng)目,編碼的時(shí)候就要按照模塊化一個(gè)一個(gè)的進(jìn)行編碼磅甩。

那么為什么要使用模塊化炊林?也就是說(shuō)使用模塊化的好處有哪些呢?

首先卷要,模塊化封裝性好渣聚,封裝的意義我們也知道,其實(shí)還有個(gè)概念就是僧叉,數(shù)據(jù)的不變性奕枝,我們可以讓你操作數(shù)據(jù),但是不允許隨意改變我們?cè)瓉?lái)數(shù)據(jù)的內(nèi)容瓶堕。個(gè)人姑且這么認(rèn)為吧隘道。

第二,復(fù)用性好郎笆,我們可以在多個(gè)場(chǎng)合和情況下繼續(xù)使用谭梗,這樣我們就不會(huì)寫(xiě)太多一樣的代碼,造成浪費(fèi)時(shí)間浪費(fèi)空間宛蚓。代碼不冗余激捏。

第三,擴(kuò)展性好凄吏,也是和上面一樣的道理了远舅。

到這里,明白了模塊的具體意義之后痕钢,那么我們web前端中的模塊規(guī)范有哪些呢图柏?有好幾種,這里我們只需要明白commonJS任连、ES6這兩個(gè)蚤吹。AMD、CMD暫時(shí)就不管咯随抠。

commonJS中距辆,主要運(yùn)用在node.js服務(wù)器余佃,瀏覽器端的打包工具時(shí)Browserify暮刃。它的暴露模塊的方式是exports跨算。export.xxx = value。module.exports = value椭懊。引入模塊則是利用require ---- > var= module = require('模塊名/模塊相對(duì)路徑')

上面的都是基本語(yǔ)法诸蚕,那么我們其實(shí)應(yīng)該搞清楚,commonjs在暴露和引入模塊的時(shí)候都發(fā)生在什么時(shí)候氧猬?

在我們node運(yùn)行的時(shí)候背犯,會(huì)動(dòng)態(tài)同步的引入我們定義好的需要的模塊,這很中要盅抚,因?yàn)閚ode運(yùn)行之后漠魏,在瀏覽器端實(shí)現(xiàn)的時(shí)候會(huì)對(duì)模塊進(jìn)行編譯/轉(zhuǎn)譯/打包的處理。這時(shí)候是Browseify工作的事情了妄均。在B工作的時(shí)候柱锹,已經(jīng)將依賴(lài)的模塊包含進(jìn)來(lái),運(yùn)行的時(shí)候生成打包的js文件丰包,我們?cè)谶\(yùn)行的時(shí)候不需要在從遠(yuǎn)程引入相關(guān)依賴(lài)的模塊了禁熏。

ES6規(guī)范中,ES6內(nèi)置了模塊化的實(shí)現(xiàn)邑彪,基本語(yǔ)法定義的暴露是export瞧毙,相對(duì)于commonjs來(lái)說(shuō)表面上就是少了個(gè)S而已。不同的是引入采用的是import寄症。

定義暴露模塊分為:默認(rèn)暴露宙彪,一次暴露多個(gè)

export default + 對(duì)象 ---->為默認(rèn)暴露

export var xxx? = value1、export let yyy = value2 -----> var xxx = value1 有巧、let yyy = value2? ---->export {xxx,yyy}

利用import 引入 默認(rèn)模塊import xxx from '模塊路徑/模塊名'

利用import引入其他模塊import {xxx,yyy} from '模塊路徑/模塊名'释漆,這邊{}內(nèi)采用的是ES6中的解構(gòu)賦值。這里不詳細(xì)說(shuō)了剪决。

在使用ES6的時(shí)候在瀏覽器端運(yùn)行也需要利用Broeserify來(lái)進(jìn)行打包處理灵汪。另外還有一點(diǎn)需要注意的是。在使用ES6的時(shí)候需要將其轉(zhuǎn)換為ES5的語(yǔ)法才能運(yùn)行柑潦。因?yàn)槟壳斑€有些瀏覽器不能ES6的語(yǔ)法享言。谷歌瀏覽器可以支持。先說(shuō)到這里好了渗鬼。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末览露,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子譬胎,更是在濱河造成了極大的恐慌差牛,老刑警劉巖命锄,帶你破解...
    沈念sama閱讀 210,914評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異偏化,居然都是意外死亡脐恩,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,935評(píng)論 2 383
  • 文/潘曉璐 我一進(jìn)店門(mén)侦讨,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)驶冒,“玉大人,你說(shuō)我怎么就攤上這事韵卤∑郏” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,531評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵沈条,是天一觀的道長(zhǎng)需忿。 經(jīng)常有香客問(wèn)我,道長(zhǎng)蜡歹,這世上最難降的妖魔是什么屋厘? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,309評(píng)論 1 282
  • 正文 為了忘掉前任,我火速辦了婚禮季稳,結(jié)果婚禮上擅这,老公的妹妹穿的比我還像新娘。我一直安慰自己景鼠,他們只是感情好仲翎,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,381評(píng)論 5 384
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著铛漓,像睡著了一般溯香。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上浓恶,一...
    開(kāi)封第一講書(shū)人閱讀 49,730評(píng)論 1 289
  • 那天玫坛,我揣著相機(jī)與錄音,去河邊找鬼包晰。 笑死湿镀,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的伐憾。 我是一名探鬼主播勉痴,決...
    沈念sama閱讀 38,882評(píng)論 3 404
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼树肃!你這毒婦竟也來(lái)了蒸矛?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,643評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎雏掠,沒(méi)想到半個(gè)月后斩祭,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,095評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡乡话,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,448評(píng)論 2 325
  • 正文 我和宋清朗相戀三年摧玫,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蚊伞。...
    茶點(diǎn)故事閱讀 38,566評(píng)論 1 339
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡席赂,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出时迫,到底是詐尸還是另有隱情,我是刑警寧澤谓晌,帶...
    沈念sama閱讀 34,253評(píng)論 4 328
  • 正文 年R本政府宣布掠拳,位于F島的核電站,受9級(jí)特大地震影響纸肉,放射性物質(zhì)發(fā)生泄漏溺欧。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,829評(píng)論 3 312
  • 文/蒙蒙 一柏肪、第九天 我趴在偏房一處隱蔽的房頂上張望姐刁。 院中可真熱鬧,春花似錦烦味、人聲如沸聂使。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,715評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)柏靶。三九已至,卻和暖如春溃论,著一層夾襖步出監(jiān)牢的瞬間屎蜓,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,945評(píng)論 1 264
  • 我被黑心中介騙來(lái)泰國(guó)打工钥勋, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留炬转,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,248評(píng)論 2 360
  • 正文 我出身青樓算灸,卻偏偏與公主長(zhǎng)得像扼劈,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子乎婿,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,440評(píng)論 2 348

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

  • 原文鏈接:http://www.cnblogs.com/lvdabao/p/js-modules-develop....
    舌尖上的大胖閱讀 699評(píng)論 0 1
  • 官方中文版原文鏈接 感謝社區(qū)中各位的大力支持测僵,譯者再次奉上一點(diǎn)點(diǎn)福利:阿里云產(chǎn)品券,享受所有官網(wǎng)優(yōu)惠,并抽取幸運(yùn)大...
    HetfieldJoe閱讀 3,655評(píng)論 2 27
  • 參考資料 Modules/1.0——維基百科CommonJS Modules/1.0——伯樂(lè)在線js模塊化——博客...
    BeYanJin閱讀 3,043評(píng)論 0 5
  • ## 前言 The Module Pattern捍靠,模塊模式沐旨,也譯為模組模式,是一種通用的對(duì)代碼進(jìn)行模塊化組織與定義...
    b2e16cc43137閱讀 3,020評(píng)論 1 4
  • 一榨婆、白水出身 白水出生于1989年磁携,那個(gè)計(jì)劃生育最為嚴(yán)苛的時(shí)代。那個(gè)時(shí)候良风,村子里的大街小巷里寫(xiě)滿(mǎn)了“只生一個(gè)好谊迄,政...
    黑曼木木閱讀 733評(píng)論 0 3