国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

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

icattlecoder / 2457人閱讀

摘要:運(yùn)行時(shí)用來(lái)創(chuàng)建實(shí)例渲染并處理虛擬等的代碼。基本上就是除去編譯器的其它一切。版本可以通過(guò)標(biāo)簽直接用在瀏覽器中。為這些打包工具提供的默認(rèn)文件是只有運(yùn)行時(shí)的構(gòu)建。為瀏覽器提供的用于在現(xiàn)代瀏覽器中通過(guò)直接導(dǎo)入。

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)和開(kāi)發(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 開(kāi)發(fā)語(yǔ)言和開(kāi)發(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)目開(kāi)源協(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ò)

閱讀需要支付1元查看
<