Vue源碼之目錄結(jié)構(gòu)

Vue版本:2.6.9

源碼結(jié)構(gòu)圖

├─ .circleci                   // 包含CircleCI持續(xù)集成/持續(xù)部署工具的配置文件
├─ .github                   // 項(xiàng)目相關(guān)的說(shuō)明文檔,上面的說(shuō)明文檔就在此文件夾
├─ benchmarks                 // 基準(zhǔn),性能測(cè)試文件亭病,Vue的跑分demo,比如大數(shù)據(jù)量的table或者渲染大量SVG
├─ dist                       // 構(gòu)建后輸出的不同版本Vue文件(UMD贪婉、CommonJS宽堆、ES 生產(chǎn)和開發(fā)包)
├─ examples                   // 部分示例,用Vue寫的一些小demo
├─ flow                       // flow 因?yàn)閂ue使用了 [Flow](https://flow.org/) 來(lái)進(jìn)行靜態(tài)類型檢查期丰,靜態(tài)類型檢查類型聲明文件
├─ packages                   // 包含服務(wù)端渲染和模板編譯器兩種不同的NPM包护侮,是提供給不同使用場(chǎng)景使用的
├─ scripts                   // 存放npm腳本配置文件敌完,結(jié)合webpack、rollup進(jìn)行編譯羊初、測(cè)試滨溉、構(gòu)建等操作(使用者不需要關(guān)心)
│   ├─ alias.js              // 模塊導(dǎo)入所有源代碼和測(cè)試中使用的別名
│   ├─ config.js             // 包含在'dist/`中找到的所有文件的生成配置
│   ├─ build.js               // 對(duì) config.js 中所有的rollup配置進(jìn)行構(gòu)建
├─ src                        // 主要源碼所在位置,核心內(nèi)容
│   ├─ compiler               // 解析模版相關(guān)
│       ├─ codegen            // 把AST轉(zhuǎn)換為Render函數(shù)
│       ├─ directives         // 通用生成Render函數(shù)之前需要處理的指令
│       ├─ parser              // 解析模版成AST
│   ├─ core                    // Vue核心代碼长赞,包括內(nèi)置組件晦攒,全局API封裝,Vue 實(shí)例化得哆,觀察者脯颜,虛擬DOM, 工具函數(shù)等等。
│       ├─ components          // 組件相關(guān)屬性贩据,主要是Keep-Alive
│       ├─ global-api          // Vue全局API栋操,如Vue.use,Vue.extend,Vue.mixin等
│       ├─ instance            // 實(shí)例化相關(guān)內(nèi)容,生命周期乐设、事件等
│       ├─ observer            // 響應(yīng)式核心目錄讼庇,雙向數(shù)據(jù)綁定相關(guān)文件
│       ├─ util                // 工具方法
│       └─ vdom                // 包含虛擬DOM 創(chuàng)建(creation)和打補(bǔ)丁(patching) 的代碼
│   ├─ platforms               // 和平臺(tái)相關(guān)的內(nèi)容绎巨,Vue.js 是一個(gè)跨平臺(tái)的MVVM 框架(web近尚、native、weex)
│       ├─ web                 // web端
│           ├─ compiler        // web端編譯相關(guān)代碼场勤,用來(lái)編譯模版成render函數(shù)basic.js
│           ├─ runtime         // web端運(yùn)行時(shí)相關(guān)代碼戈锻,用于創(chuàng)建Vue實(shí)例等
│           ├─ server          // 服務(wù)端渲染
│           └─ util            // 相關(guān)工具類
│       └─ weex                // 基于通用跨平臺(tái)的 Web 開發(fā)語(yǔ)言和開發(fā)經(jīng)驗(yàn)歼跟,來(lái)構(gòu)建 Android、iOS 和 Web 應(yīng)用
│   ├─ server                  // 服務(wù)端渲染(ssr)
│   ├─ sfc                     // 轉(zhuǎn)換單文件組件(*.vue)
│   └─ shared                  // 全局共享的方法和常量
├─ test                        // test 測(cè)試用例
├─ types                       // Vue新版本支持TypeScript格遭,主要是TypeScript類型聲明文件
├─ node_modules               // npm包存放目錄
|-- .babelrc.js               // babel配置
|-- .editorconfig             // 文本編碼樣式配置文件
|-- .eslintignore             // eslint校驗(yàn)忽略文件
|-- .eslintrc.js              // eslint配置文件
|-- .flowconfig               // flow配置文件
|-- .gitignore               // Git提交忽略文件配置
|-- BACKERS.md               // 贊助者信息文件
|-- LICENSE                 // 項(xiàng)目開源協(xié)議
|-- package.json             // 依賴
|-- README.md               // 說(shuō)明文件
|-- yarn.lock               // yarn版本鎖定文件

Vue 不同的構(gòu)建版本對(duì)比

UMD CommonJS ES Module (基于構(gòu)建工具使用) ES Module (直接用于瀏覽器)
完整版 vue.js vue.common.js vue.esm.js vue.esm.browser.js
只包含運(yùn)行時(shí)版 vue.runtime.js vue.runtime.common.js vue.runtime.esm.js -
完整版 (生產(chǎn)環(huán)境) vue.min.js - - vue.esm.browser.min.js
只包含運(yùn)行時(shí)版 (生產(chǎn)環(huán)境) vue.runtime.min.js - - -

術(shù)語(yǔ)解釋

  • 完整版:同時(shí)包含編譯器和運(yùn)行時(shí)的版本哈街。
  • 編譯器:用來(lái)將模板字符串編譯成為 JavaScript 渲染函數(shù)的代碼。
  • 運(yùn)行時(shí): 用來(lái)創(chuàng)建 Vue 實(shí)例拒迅、渲染并處理虛擬 DOM 等的代碼骚秦。基本上就是除去編譯器的其它一切璧微。
  • UMD:UMD 版本可以通過(guò) <script> 標(biāo)簽直接用在瀏覽器中作箍。jsDelivr CDN 的 https://cdn.jsdelivr.net/npm/vue 默認(rèn)文件就是運(yùn)行時(shí) + 編譯器的 UMD 版本 (vue.js)。
  • CommonJS:CommonJS 版本用來(lái)配合老的打包工具比如 Browserify 或 webpack 1前硫。這些打包工具的默認(rèn)文件 (pkg.main) 是只包含運(yùn)行時(shí)的 CommonJS 版本 (vue.runtime.common.js) 胞得。
  • ES Module: 從 2.6 開始 Vue 會(huì)提供兩個(gè) ES Modules (ESM) 構(gòu)建文件:
    • 為打包工具提供的 ESM:為諸如 webpack 2 或 Rollup 提供的現(xiàn)代打包工具。ESM 格式被設(shè)計(jì)為可以被靜態(tài)分析屹电,所以打包工具可以利用這一點(diǎn)來(lái)進(jìn)行“tree-shaking”并將用不到的代碼排除出最終的包阶剑。為這些打包工具提供的默認(rèn)文件 (pkg.module) 是只有運(yùn)行時(shí)的 ES Module 構(gòu)建 (vue.runtime.esm.js)。
    • 為瀏覽器提供的 ESM (2.6+):用于在現(xiàn)代瀏覽器中通過(guò) <script type="module"> 直接導(dǎo)入危号。

注意:如果你需要在客戶端編譯模板 (比如傳入一個(gè)字符串給 template 選項(xiàng)牧愁,或掛載到一個(gè)元素上并以其 DOM 內(nèi)部的 HTML 作為模板),就將需要加上編譯器

以上是本期全部?jī)?nèi)容葱色,欲知后事如何递宅,請(qǐng)聽下回分解<( ̄︶ ̄)↗[GO!]

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市苍狰,隨后出現(xiàn)的幾起案子办龄,更是在濱河造成了極大的恐慌,老刑警劉巖淋昭,帶你破解...
    沈念sama閱讀 212,816評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件俐填,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡翔忽,警方通過(guò)查閱死者的電腦和手機(jī)英融,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,729評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)歇式,“玉大人驶悟,你說(shuō)我怎么就攤上這事〔氖В” “怎么了痕鳍?”我有些...
    開封第一講書人閱讀 158,300評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我笼呆,道長(zhǎng)熊响,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,780評(píng)論 1 285
  • 正文 為了忘掉前任诗赌,我火速辦了婚禮汗茄,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘铭若。我一直安慰自己洪碳,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,890評(píng)論 6 385
  • 文/花漫 我一把揭開白布叼屠。 她就那樣靜靜地躺著偶宫,像睡著了一般。 火紅的嫁衣襯著肌膚如雪环鲤。 梳的紋絲不亂的頭發(fā)上纯趋,一...
    開封第一講書人閱讀 50,084評(píng)論 1 291
  • 那天,我揣著相機(jī)與錄音冷离,去河邊找鬼吵冒。 笑死,一個(gè)胖子當(dāng)著我的面吹牛西剥,可吹牛的內(nèi)容都是我干的痹栖。 我是一名探鬼主播,決...
    沈念sama閱讀 39,151評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼瞭空,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼揪阿!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起咆畏,我...
    開封第一講書人閱讀 37,912評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤南捂,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后旧找,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體溺健,經(jīng)...
    沈念sama閱讀 44,355評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,666評(píng)論 2 327
  • 正文 我和宋清朗相戀三年钮蛛,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了鞭缭。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,809評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡魏颓,死狀恐怖岭辣,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情甸饱,我是刑警寧澤沦童,帶...
    沈念sama閱讀 34,504評(píng)論 4 334
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響搞动,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜渣刷,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,150評(píng)論 3 317
  • 文/蒙蒙 一鹦肿、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧辅柴,春花似錦箩溃、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至股冗,卻和暖如春霹陡,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背止状。 一陣腳步聲響...
    開封第一講書人閱讀 32,121評(píng)論 1 267
  • 我被黑心中介騙來(lái)泰國(guó)打工烹棉, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人怯疤。 一個(gè)月前我還...
    沈念sama閱讀 46,628評(píng)論 2 362
  • 正文 我出身青樓浆洗,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親集峦。 傳聞我的和親對(duì)象是個(gè)殘疾皇子伏社,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,724評(píng)論 2 351

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