摘要:運(yùn)行時(shí)用來創(chuàng)建實(shí)例渲染并處理虛擬等的代碼?;旧暇褪浅ゾ幾g器的其它一切。版本可以通過標(biāo)簽直接用在瀏覽器中。為這些打包工具提供的默認(rèn)文件是只有運(yùn)行時(shí)的構(gòu)建。為瀏覽器提供的用于在現(xiàn)代瀏覽器中通過直接導(dǎo)入。
Vue版本:2.6.9
源碼結(jié)構(gòu)圖├─ .circleci // 包含CircleCI持續(xù)集成/持續(xù)部署工具的配置文件 ├─ .github // 項(xiàng)目相關(guān)的說明文檔,上面的說明文檔就在此文件夾 ├─ 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/) 來進(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)代碼,用來編譯模版成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),來構(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 // 說明文件 |-- 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ùn)行時(shí)的版本。
編譯器:用來將模板字符串編譯成為 JavaScript 渲染函數(shù)的代碼。
運(yùn)行時(shí): 用來創(chuàng)建 Vue 實(shí)例、渲染并處理虛擬 DOM 等的代碼?;旧暇褪浅ゾ幾g器的其它一切。
UMD:UMD 版本可以通過 標(biāo)簽直接用在瀏覽器中。jsDelivr CDN 的 https://cdn.jsdelivr.net/npm/vue 默認(rèn)文件就是運(yùn)行時(shí) + 編譯器的 UMD 版本 (vue.js)。
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)代瀏覽器中通過 直接導(dǎo)入。
注意:如果你需要在客戶端編譯模板 (比如傳入一個(gè)字符串給 template 選項(xiàng),或掛載到一個(gè)元素上并以其 DOM 內(nèi)部的 HTML 作為模板),就將需要加上編譯器
以上是本期全部?jī)?nèi)容,欲知后事如何,請(qǐng)聽下回分解<( ̄︶ ̄)↗[GO!]
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/116010.html
摘要:運(yùn)行時(shí)用來創(chuàng)建實(shí)例渲染并處理虛擬等的代碼?;旧暇褪浅ゾ幾g器的其它一切。版本可以通過標(biāo)簽直接用在瀏覽器中。為這些打包工具提供的默認(rèn)文件是只有運(yùn)行時(shí)的構(gòu)建。為瀏覽器提供的用于在現(xiàn)代瀏覽器中通過直接導(dǎo)入。 Vue版本:2.6.9 源碼結(jié)構(gòu)圖 ├─ .circleci // 包含CircleCI持續(xù)集成/持續(xù)部署工具的配置文件 ├─ .github ...
摘要:運(yùn)行時(shí)用來創(chuàng)建實(shí)例渲染并處理虛擬等的代碼。基本上就是除去編譯器的其它一切。版本可以通過標(biāo)簽直接用在瀏覽器中。為這些打包工具提供的默認(rèn)文件是只有運(yùn)行時(shí)的構(gòu)建。為瀏覽器提供的用于在現(xiàn)代瀏覽器中通過直接導(dǎo)入。 Vue版本:2.6.9 源碼結(jié)構(gòu)圖 ├─ .circleci // 包含CircleCI持續(xù)集成/持續(xù)部署工具的配置文件 ├─ .github ...
摘要:今天開始打算用個(gè)月的時(shí)間讀一些源碼,先從的開始吧。進(jìn)入這個(gè)文件,它引用了來進(jìn)行實(shí)例化。也就是初始化的核心代碼了。 今天開始打算用3個(gè)月的時(shí)間讀一些源碼,先從MVVM的vue開始吧。vue是一個(gè)非常不錯(cuò)的前端框架,不僅體積小,性能高,而且學(xué)習(xí)曲線非常平緩,很容易上手。官方文檔也很詳解,配套的構(gòu)建工具很完事。還有很多第三方的組件和組件庫(kù),可以讓開發(fā)者更高效的工作。 源碼是vue2...
摘要:實(shí)際上,我在看代碼的過程中順手提交了這個(gè),作者眼明手快,當(dāng)天就進(jìn)行了修復(fù),現(xiàn)在最新的代碼里已經(jīng)不是這個(gè)樣子了而且狀態(tài)機(jī)標(biāo)識(shí)由字符串換成了數(shù)字常量,解析更準(zhǔn)確的同時(shí)執(zhí)行效率也會(huì)更高。 最近饒有興致的又把最新版?Vue.js?的源碼學(xué)習(xí)了一下,覺得真心不錯(cuò),個(gè)人覺得 Vue.js 的代碼非常之優(yōu)雅而且精辟,作者本身可能無 (bu) 意 (xie) 提及這些。那么,就讓我來吧:) 程序結(jié)構(gòu)梳...
閱讀 3207·2021-11-25 09:43
閱讀 3417·2021-11-11 16:54
閱讀 843·2021-11-02 14:42
閱讀 3769·2021-09-30 09:58
閱讀 3675·2021-09-29 09:44
閱讀 1287·2019-08-30 15:56
閱讀 2109·2019-08-30 15:54
閱讀 2995·2019-08-30 15:43