摘要:學習源碼時,我們首先需要看的是文件,該文件里配置了的依賴以及開發(fā)環(huán)境和生產環(huán)境的編譯的啟動腳本等其他信息。一個是完整版,一個是運行時。運行時用來創(chuàng)建實例渲染并處理虛擬等的代碼?;旧暇褪浅ゾ幾g器的其它一切。
學習vue源碼時,我們首先需要看的是package.json文件,該文件里配置了vue的依賴以及開發(fā)環(huán)境和生產環(huán)境的編譯的啟動腳本等其他信息。首先我們需要關注的是script。我們這里先看第一個dev腳本:
"dev": "rollup -w -c scripts/config.js --environment TARGET:web-full-dev"
我們可以看到vue是采用了rollup編譯的腳本,然后對應的查看其配置文件config.js
const builds = { ... // Runtime+compiler development build (Browser) "web-full-dev": { entry: resolve("web/entry-runtime-with-compiler.js"), dest: resolve("dist/vue.js"), format: "umd", env: "development", alias: { he: "./entity-decoder" }, banner }, ... }
在該文件中我們可以找到web-full-dev的配置項,并且知道其編譯的文件為"web/entry-runtime-with-compiler.js"
那么我們就需要去找到該文件了。
我們可以發(fā)現(xiàn)entry-runtime-with-compiler.js的其中有一行代碼是:
import Vue from "./runtime/index"
然后繼續(xù)跟著代碼往上找,我們會發(fā)現(xiàn)還是嵌套了好幾層,最后在"/instance/index"中找到我們vue的定義:最終其路勁如下:
/src/platforms/web/web-runtime-with-compiler.js => /src/platforms/web/runtime/index.js => /src/core/index.js => /src/core/instance/index.js
最終我們在instance/index.js上找到了vue的廬山真面目,他的構造函數及其簡單:
function Vue (options) { if (process.env.NODE_ENV !== "production" && !(this instanceof Vue) ) { warn("Vue is a constructor and should be called with the `new` keyword") } this._init(options) }
我們可以發(fā)現(xiàn)它并沒有使用class的,只是一個普通的構造函數,通過 !(this instanceof Vue) 來強制使用new來構建。
之所以不采用class,個人理解是為了更好的把代碼拆分。原型上的方法只需要通過prototype來添加。如下
initMixin(Vue) // 這里主要注冊了_init stateMixin(Vue) // $set,$delete,$watch eventsMixin(Vue) // $on, $once, $off, $emit lifecycleMixin(Vue) // _update, $forceUpdate,$destroy renderMixin(Vue) // $nextTick, _render
這邊都是基于在Vue上擴展方法,這樣就把代碼分離開發(fā),方便維護。不需要全部寫到Vue函數內部。
然后我們往回走,我們可以看到/src/core/index.js 中
initGlobalAPI(Vue) Object.defineProperty(Vue.prototype, "$isServer", { get: isServerRendering }) Object.defineProperty(Vue.prototype, "$ssrContext", { get () { /* istanbul ignore next */ return this.$vnode && this.$vnode.ssrContext } }) Object.defineProperty(Vue, "FunctionalRenderContext", { value: FunctionalRenderContext }) Vue.version = "__VERSION__"
該文件中主要就是注冊全局API,以供我們內部或外部使用
再往上/src/platforms/web/runtime/index.js,我們可以看到
// install platform specific utils Vue.config.mustUseProp = mustUseProp Vue.config.isReservedTag = isReservedTag Vue.config.isReservedAttr = isReservedAttr Vue.config.getTagNamespace = getTagNamespace Vue.config.isUnknownElement = isUnknownElement // install platform runtime directives & components extend(Vue.options.directives, platformDirectives) extend(Vue.options.components, platformComponents) // install platform patch function Vue.prototype.__patch__ = inBrowser ? patch : noop // 用于把vNode顯示到dom上的方法,這邊要區(qū)分是瀏覽器環(huán)境還是weex環(huán)境 // public mount method Vue.prototype.$mount = function () { ..... } // 把dom掛在到頁面上
這邊就是注冊一些全局的工具,以及patch方法
那么再往上:src/platforms/web/web-runtime-with-compiler.js, 這個文件中主要就是重寫$mount
const mount = Vue.prototype.$mount Vue.prototype.$mount = function ( ){ ... }
那么為什么要重寫呢?原來在runtime里面的$mount方法是沒有編譯功能的,而最后一個重寫就是增加了編譯。
在vue腳手架我們會讓我們選擇哪個版本:如下圖
這就是2個版本的區(qū)別,是否包含編譯功能。一個是完整版,一個是運行時。
vue官方屬于解釋了:
完整版:同時包含編譯器和運行時的版本。 編譯器:用來將模板字符串編譯成為 JavaScript 渲染函數的代碼。 運行時:用來創(chuàng)建 Vue 實例、渲染并處理虛擬 DOM 等的代碼?;旧暇褪浅ゾ幾g器的其它一切。 如果你需要在客戶端編譯模板 (比如傳入一個字符串給 template 選項,或掛載到一個元素上并以其 DOM 內部的 HTML 作為模板),就將需要加上編譯器,即完整版: // 需要編譯器 new Vue({ template: "{{ hi }}" }) // 不需要編譯器 new Vue({ render (h) { return h("div", this.hi) } })
重寫$mount方法就是對template就行了編譯轉換為render方法
好了這邊就簡要的介紹了vue的入口。
您的點贊是我繼續(xù)努力的動力!
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://systransis.cn/yun/98936.html
摘要:其中執(zhí)行命令是我們當前所關注的,對于項目的文件結構,我們需要去找到項目的啟動的入口文件,接下來我們去一步一步的找到分析命令是一個模塊打包器。 打算開始學習vue的源碼開始,我開始 serach 關鍵詞:vue 源碼,可是發(fā)現(xiàn)很多都不是我想要看到的東西,所以打算記錄下來,學習的記錄和日后分享。我在想這個文章的名字時,手把手系列?十分鐘系列?小白到大佬系列?都不是,只是單純的學習筆記 文件...
前言 本文所有內容全部發(fā)布再個人博客主頁 https://github.com/muwoo/blogs歡迎訂閱。不過最近因為事情比較多,有一段時間沒有更新了,后面打算繼續(xù)不斷學習更新,歡迎小伙伴一起溝通交流~ 最近更新 前端單測的那些事 基于virtual dom 的canvas渲染 js Event loop 機制簡介 axios 核心源碼實現(xiàn)原理 JS 數據類型、賦值、深拷貝和淺拷貝 j...
前言 本文所有內容全部發(fā)布再個人博客主頁 https://github.com/muwoo/blogs歡迎訂閱。不過最近因為事情比較多,有一段時間沒有更新了,后面打算繼續(xù)不斷學習更新,歡迎小伙伴一起溝通交流~ 最近更新 前端單測的那些事 基于virtual dom 的canvas渲染 js Event loop 機制簡介 axios 核心源碼實現(xiàn)原理 JS 數據類型、賦值、深拷貝和淺拷貝 j...
前言 本文所有內容全部發(fā)布再個人博客主頁 https://github.com/muwoo/blogs歡迎訂閱。不過最近因為事情比較多,有一段時間沒有更新了,后面打算繼續(xù)不斷學習更新,歡迎小伙伴一起溝通交流~ 最近更新 前端單測的那些事 基于virtual dom 的canvas渲染 js Event loop 機制簡介 axios 核心源碼實現(xiàn)原理 JS 數據類型、賦值、深拷貝和淺拷貝 j...
閱讀 2015·2021-09-13 10:23
閱讀 2345·2021-09-02 09:47
閱讀 3805·2021-08-16 11:01
閱讀 1227·2021-07-25 21:37
閱讀 1608·2019-08-30 15:56
閱讀 542·2019-08-30 13:52
閱讀 3136·2019-08-26 10:17
閱讀 2453·2019-08-23 18:17