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

資訊專欄INFORMATION COLUMN

每天讀一點源碼---vue的初始化

luffyZh / 1908人閱讀

摘要:今天開始打算用個月的時間讀一些源碼,先從的開始吧。進入這個文件,它引用了來進行實例化。也就是初始化的核心代碼了。

今天開始打算用3個月的時間讀一些源碼,先從MVVM的vue開始吧。
vue是一個非常不錯的前端框架,不僅體積小,性能高,而且學習曲線非常平緩,很容易上手。官方文檔也很詳解,配套的構建工具很完事。還有很多第三方的組件和組件庫,可以讓開發(fā)者更高效的工作。

源碼是vue2.4.0版本。

項目結構

在看源碼之前先分析下項目結構,對項目有一個比較全面的了解。

vue-dev項目結構

├── build --------------------------------- 構建相關文件
├── dist ---------------------------------- 生成文件的輸出目錄
├── examples ------------------------------ 一些vue使用的例子
├── flow ---------------------------------- flow(Flow is a static type checker for your JavaScript code.)類型聲明
├── package.json -------------------------- 依賴管理
├── test ---------------------------------- 測試文件
├── src ----------------------------------- 源碼
│   ├── compiler -------------------------- 編譯器代碼,template-->render function
│   │   ├── parser ------------------------ 模板字符串轉-->抽象語法樹
│   │   ├── codegen ----------------------- 抽象語法樹(AST)-->render function
│   │   ├── optimizer.js ------------------ 分析靜態(tài)樹,優(yōu)化vdom渲染
│   ├── core ------------------------------ 核心代碼
│   │   ├── observer ---------------------- 雙向綁定,數(shù)據(jù)觀察的代碼
│   │   ├── vdom -------------------------- VNode對象&patch方法的代碼
│   │   ├── instance ---------------------- Vue構造函數(shù)相關的代碼
│   │   ├── global-api -------------------- Vue構造函數(shù)掛載全局方法(靜態(tài)方法)或屬性的代碼
│   │   ├── components -------------------- 通用組件
│   ├── server ---------------------------- SSR(server-side rendering)的代碼
│   ├── platforms ------------------------- 平臺相關代碼
│   ├── sfc ------------------------------- 對單文件組件進行解析
│   ├── shared ---------------------------- 通用代碼(util之類)

vue的初始化

了解了大體的目錄結構之后,就從package.json開始看起了。在package.json文件里我們發(fā)現(xiàn)在執(zhí)行npm run dev的時候,執(zhí)行的下面這個腳本,也就是Target是web-full-dev

"scripts": {
    "dev": "rollup -w -c build/config.js --environment TARGET:web-full-dev",
     ...
  }

之后去build/config.js里去看看 web-full-dev是什么

  "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
  } 

我們看到這個的入口文件是entry-runtime-with-compiler.js。進入這個文件,它引用了/src/platform/runtime/index--->/src/core/index--->/src/core/instance/index來進行實例化vue。
instance/index.js也就是vue初始化的核心代碼了。

//初始化入口
initMixin(Vue)
//數(shù)據(jù)綁定,$watch方法
stateMixin(Vue)
//事件方法,比如$on,$off,$emit
eventsMixin(Vue)
//生命周期方法
lifecycleMixin(Vue)
//渲染方法,用來生成render function 和 VNode
renderMixin(Vue)

initMixin方法
首選來具體看一下initMixin里做了什么

initLifecycle -- 定義$parent, $root, $children, $refs, _watch,
_inactive, _directInactive, _isMounted, _isDestroyed, _isBeingDestroyed給vue實例

initEvents -- 創(chuàng)建_events事件管理對象,$options._parentListeners監(jiān)聽父組件listener

initRender --創(chuàng)建_vnode,_staticTrees,$slots,$scopedSlots,$createElement給vue實例

callHook(vm, "beforeCreate")--執(zhí)行beforeCreate的鉤子方法

initState--

  initProps--綁定props
  initMethods--綁定方法
  initData-通過observe進行數(shù)據(jù)綁定, 給每一個data的屬性加上getter,setter.

callHook(vm, "created")--執(zhí)行created的鉤子方法

vm.$mount(vm.$options.el) -- 通過el or template or render function 渲染dom

stateMixin方法
數(shù)據(jù)綁定 將$watch,$data,$props,$set,$delete加在Vue.prototype上

eventsMixin方法
初始化事件方法,定義$on,$off,$emit,$once到Vue.prototype上

lifecycleMixin方法
生命周期方法,定義_update,$forceUpdate,$destroy到Vue.prototype上

renderMixin方法
渲染方法,用來生成render function 和 VNode

有不足之處請指正,歡迎一起交流學習。

輪子工廠--一個分享優(yōu)秀的vue,angular組件的網(wǎng)站

文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://systransis.cn/yun/87198.html

相關文章

  • 【自己讀源】Netty4.X系列(二) 啟動類成員Channel

    摘要:下面無恥的貼點源碼。啟動類我們也學,把啟動類抽象成兩層,方便以后寫客戶端。別著急,我們慢慢來,下一篇我們會了解以及他的成員,然后,完善我們的程序,增加其接收數(shù)據(jù)的能力。文章的源碼我會同步更新到我的上,歡迎大家,哈哈。 廢話兩句 這次更新拖了很長時間,第一是自己生病了,第二是因為最開始這篇想寫的很大,然后構思了很久,發(fā)現(xiàn)不太合適把很多東西寫在一起,所以做了點拆分,準備國慶前完成這篇博客。...

    waterc 評論0 收藏0
  • underscore 該如何閱讀?

    摘要:所以它與其他系列的文章并不沖突,完全可以在閱讀完這個系列后,再跟著其他系列的文章接著學習。如何閱讀我在寫系列的時候,被問的最多的問題就是該怎么閱讀源碼我想簡單聊一下自己的思路。感謝大家的閱讀和支持,我是冴羽,下個系列再見啦 前言 別名:《underscore 系列 8 篇正式完結!》 介紹 underscore 系列是我寫的第三個系列,前兩個系列分別是 JavaScript 深入系列、...

    weknow619 評論0 收藏0

發(fā)表評論

0條評論

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