基于vue 2.6.11
目錄結(jié)構(gòu)
├─ .circleci // 持續(xù)集成部署的配置文件
├─ .github // github提交說明,包括issue,commit,contribute,pull request等
├─ benchmarks // 性能測試文件。比如大數(shù)據(jù)量的table或者渲染大量SVG
├─ dist // 構(gòu)建輸出的不同版本vue文件。UMD,Commonjs,ESModule,完整版,運(yùn)行時(shí)版,開發(fā)版,生產(chǎn)版等
├─ examples // 部分示例,用Vue寫的一些小demo
├─ flow // Vue使用了 [Flow](https://flow.org/) 來進(jìn)行靜態(tài)類型檢查,目錄包含靜態(tài)類型檢查類型聲明文件
├─ packages // 包含服務(wù)端渲染和模板編譯器兩種不同的NPM包,提供不同使用場景
├─ scripts // 存放npm腳本配置文件,結(jié)合webpack、rollup進(jìn)行編譯、測試、構(gòu)建等操作
│ ├─ alias.js // 模塊導(dǎo)入所有源代碼和測試中使用的別名
│ ├─ config.js // 不同輸出版本的打包配置文件
│ ├─ build.js // 對 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)屬性
│ ├─ global-api // Vue全局API,如Vue.use,Vue.extend,Vue.mixin等
│ ├─ instance // Vue的類定義
│ ├─ 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)代碼,用來編譯模版成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ā)語言和開發(fā)經(jīng)驗(yàn),來構(gòu)建 Android、iOS 和 Web 應(yīng)用
│ ├─ server // 服務(wù)端渲染(ssr)
│ ├─ sfc // 轉(zhuǎn)換單文件組件(*.vue)
│ └─ shared // 全局共享的方法和常量
├─ test // test 測試用例
├─ 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 // 說明文件
|-- yarn.lock // yarn版本鎖定文件
打包版本
| UMD | CommonJS | ES Module | |
|---|---|---|---|
| 完整版 | vue.js | vue.common.js | vue.esm.js |
| 運(yùn)行時(shí)版 | vue.runtime.js | vue.runtime.common.js | vue.runtime.esm.js |
| 完整版(生產(chǎn)) | vue.min.js | ||
| 運(yùn)行時(shí)版 (生產(chǎn)) | vue.runtime.min.js |
術(shù)語解釋
完整版:同時(shí)包含編譯器和運(yùn)行時(shí)的版本。
編譯器:用來將模板字符串編譯成為 JavaScript 渲染函數(shù)的代碼。
運(yùn)行時(shí):用來創(chuàng)建 Vue 實(shí)例、渲染并處理虛擬 DOM 等的代碼。基本上就是除去編譯器的其它一切。
UMD:UMD 版本可以通過
<script>標(biāo)簽直接用在瀏覽器中。CommonJS:CommonJS 版本用來配合老的打包工具比如 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)來進(jìn)行“tree-shaking”并將用不到的代碼排除出最終的包。為這些打包工具提供的默認(rèn)文件 (
pkg.module) 是只有運(yùn)行時(shí)的 ES Module 構(gòu)建 (vue.runtime.esm.js)。為瀏覽器提供的 ESM (2.6+):用于在現(xiàn)代瀏覽器中通過
<script type="module">直接導(dǎo)入。
詳細(xì)版本信息,請參考https://cn.vuejs.org/v2/guide/installation.html