成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

vue源碼學習(一)——從入口開始

ybak / 2044人閱讀

摘要:學習源碼時,我們首先需要看的是文件,該文件里配置了的依賴以及開發(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

相關文章

  • Vue源碼學習)——追根究底Vue

    摘要:其中執(zhí)行命令是我們當前所關注的,對于項目的文件結構,我們需要去找到項目的啟動的入口文件,接下來我們去一步一步的找到分析命令是一個模塊打包器。 打算開始學習vue的源碼開始,我開始 serach 關鍵詞:vue 源碼,可是發(fā)現(xiàn)很多都不是我想要看到的東西,所以打算記錄下來,學習的記錄和日后分享。我在想這個文章的名字時,手把手系列?十分鐘系列?小白到大佬系列?都不是,只是單純的學習筆記 文件...

    Harriet666 評論0 收藏0
  • 打前端博客壓壓驚

    前言 本文所有內容全部發(fā)布再個人博客主頁 https://github.com/muwoo/blogs歡迎訂閱。不過最近因為事情比較多,有一段時間沒有更新了,后面打算繼續(xù)不斷學習更新,歡迎小伙伴一起溝通交流~ 最近更新 前端單測的那些事 基于virtual dom 的canvas渲染 js Event loop 機制簡介 axios 核心源碼實現(xiàn)原理 JS 數據類型、賦值、深拷貝和淺拷貝 j...

    wangbinke 評論0 收藏0
  • 打前端博客壓壓驚

    前言 本文所有內容全部發(fā)布再個人博客主頁 https://github.com/muwoo/blogs歡迎訂閱。不過最近因為事情比較多,有一段時間沒有更新了,后面打算繼續(xù)不斷學習更新,歡迎小伙伴一起溝通交流~ 最近更新 前端單測的那些事 基于virtual dom 的canvas渲染 js Event loop 機制簡介 axios 核心源碼實現(xiàn)原理 JS 數據類型、賦值、深拷貝和淺拷貝 j...

    villainhr 評論0 收藏0
  • 打前端博客壓壓驚

    前言 本文所有內容全部發(fā)布再個人博客主頁 https://github.com/muwoo/blogs歡迎訂閱。不過最近因為事情比較多,有一段時間沒有更新了,后面打算繼續(xù)不斷學習更新,歡迎小伙伴一起溝通交流~ 最近更新 前端單測的那些事 基于virtual dom 的canvas渲染 js Event loop 機制簡介 axios 核心源碼實現(xiàn)原理 JS 數據類型、賦值、深拷貝和淺拷貝 j...

    xiaoqibTn 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<