欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue之Watcher源碼解析(2)

 更新時間:2017年07月19日 11:35:58   作者:QH-Jimmy  
這篇文章主要為大家詳細介紹了Vue源碼之Watcher的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下

接著上節(jié)Vue Watcher源碼的話,繼續(xù)探討,目前是這么個過程:

函數(shù)大概是這里:

// line-3846
  Vue.prototype._render = function() {

    // 獲取參數(shù)

    try {
      // 死在這兒
      vnode = render.call(vm._renderProxy, vm.$createElement);
    } catch (e) {
      // 報render錯誤
    }
    // return empty vnode in case the render function errored out
    if (!(vnode instanceof VNode)) {
      // 返回空節(jié)點
    }
    // set parent
    vnode.parent = _parentVnode;
    return vnode
  };

然后,在上個月,我卡死在了render.call這個函數(shù)上面,因為所有vue實例被設(shè)置了proxy代理,所以會跳轉(zhuǎn)到各種奇怪的檢測函數(shù)中。

過了一個月,我依然看不懂,一點都不想講,所以先跳過,直接看后面!

這里假設(shè)vnode已經(jīng)返回了,來看看是個啥:

這是一個虛擬節(jié)點,由之前字符串化后的DOM樹生成,主要包含子節(jié)點、上下文、屬性、文本、標簽名、類型等屬性,這些可以直接從鍵名判斷。

得到vnode后,由于這里是根節(jié)點,所以不存在_parentVnode,直接返回。

然后到了mountComponent函數(shù):

// line-2374
  function mountComponent(vm, el, hydrating) {
    vm.$el = el;
    // error
    callHook(vm, 'beforeMount');

    var updateComponent;
    /* istanbul ignore if */
    if ("development" !== 'production' && config.performance && mark) {
      updateComponent = function() {
        // 開發(fā)者模式下的處理方式
      };
    } else {
      // 重新進入這里
      updateComponent = function() {
        vm._update(vm._render(), hydrating);
      };
    }

    vm._watcher = new Watcher(vm, updateComponent, noop);
    hydrating = false;

    // manually mounted instance, call mounted on self
    // mounted is called for render-created child components in its inserted hook
    if (vm.$vnode == null) {
      vm._isMounted = true;
      callHook(vm, 'mounted');
    }
    return vm
  }

這樣,就帶著返回的vode進入了_update函數(shù),開始正式渲染頁面。

函數(shù)如下:

// line-2374
  Vue.prototype._update = function(vnode, hydrating) {
    var vm = this;
    if (vm._isMounted) {
      callHook(vm, 'beforeUpdate');
    }
    // 保存原屬性
    var prevEl = vm.$el;
    var prevVnode = vm._vnode;
    var prevActiveInstance = activeInstance;
    activeInstance = vm;
    vm._vnode = vnode;
    // patch
    if (!prevVnode) {
      // 初始化渲染
      vm.$el = vm.__patch__(
        vm.$el, vnode, hydrating, false /* removeOnly */ ,
        vm.$options._parentElm,
        vm.$options._refElm
      );
    } else {
      // 更新
      vm.$el = vm.__patch__(prevVnode, vnode);
    }
    activeInstance = prevActiveInstance;
    // update __vue__ reference
    if (prevEl) {
      prevEl.__vue__ = null;
    }
    if (vm.$el) {
      vm.$el.__vue__ = vm;
    }
    // if parent is an HOC, update its $el as well
    // HOC => High Order Component => 高階組件
    if (vm.$vnode && vm.$parent && vm.$vnode === vm.$parent._vnode) {
      vm.$parent.$el = vm.$el;
    }
    // updated hook is called by the scheduler to ensure that children are
    // updated in a parent's updated hook.
  };

由于是初次渲染,所以會進入第一個條件分支,并調(diào)用__patch__函數(shù),傳入原生DOM節(jié)點、虛擬DOM、false三個參數(shù)。

__patch__在加載框架時候已經(jīng)注入了,見代碼:

  // line-7526
  // install platform patch function
  Vue$3.prototype.__patch__ = inBrowser ? patch : noop;

  // line-6968
  var patch = createPatchFunction({
    nodeOps: nodeOps,
    modules: modules
  });

這里,nodeOps為封裝的DOM操作操作方法,modules為屬性、指令等相關(guān)方法。

這個createPatchFunction函數(shù)的構(gòu)造相當于一個模塊,里面包含大量的方法,但是最后不是返回一個對象包含內(nèi)部方法的引用,而是返回一個函數(shù),形式大概如下:

 // line-4762
  function createPatchFunction() {
    // fn1...
    // fn2...
    return function patch() {
      // 調(diào)用內(nèi)部方法fn1,fn2...
    }
  }

方法比較多,下次再講,邊跑流程邊看。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue3+elementplus基于el-table-v2封裝公用table組件詳細代碼

    vue3+elementplus基于el-table-v2封裝公用table組件詳細代碼

    在日常開發(fā)后端管理系統(tǒng)項目中,用于展示數(shù)據(jù)多會用表格進行展示,下面這篇文章主要給大家介紹了關(guān)于vue3+elementplus基于el-table-v2封裝公用table組件的相關(guān)資料,需要的朋友可以參考下
    2023-12-12
  • Vuejs 實現(xiàn)簡易 todoList 功能 與 組件實例代碼

    Vuejs 實現(xiàn)簡易 todoList 功能 與 組件實例代碼

    本文通過實例代碼給大家介紹了Vuejs 實現(xiàn)簡易 todoList 功能 與 組件,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-09-09
  • Vue.js遞歸組件實現(xiàn)組織架構(gòu)樹和選人功能

    Vue.js遞歸組件實現(xiàn)組織架構(gòu)樹和選人功能

    這篇文章主要介紹了Vue.js遞歸組件實現(xiàn)組織架構(gòu)樹和選人功能,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • 詳解vue.js+UEditor集成 [前后端分離項目]

    詳解vue.js+UEditor集成 [前后端分離項目]

    本篇文章主要介紹了詳解vue.js+UEditor集成 [前后端分離項目] ,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • vue之keepAlive使用案例詳解

    vue之keepAlive使用案例詳解

    這篇文章主要介紹了vue之keepAlive使用案例詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-09-09
  • 解決vue-cli webpack打包開啟Gzip 報錯問題

    解決vue-cli webpack打包開啟Gzip 報錯問題

    這篇文章主要介紹了vue-cli webpack打包開啟Gzip 報錯問題的解決方法,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-07-07
  • Vue0.1的過濾代碼如何添加到Vue2.0直接使用

    Vue0.1的過濾代碼如何添加到Vue2.0直接使用

    Vue0.1的過濾代碼如何添加到Vue2.0直接使用,這篇文章主要介紹了過濾代碼添加到Vue2.0用的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • 深入了解Vue3中偵聽器watcher的實現(xiàn)原理

    深入了解Vue3中偵聽器watcher的實現(xiàn)原理

    在平時的開發(fā)工作中,我們經(jīng)常使用偵聽器幫助我們?nèi)ビ^察某個數(shù)據(jù)的變化然后去執(zhí)行一段邏輯。在?Vue.js?2.x?中,你可以通過?watch?選項去初始化一個偵聽器,稱作?watcher。本文將詳細為大家介紹一下偵聽器的實現(xiàn)原理,需要的可以參考一下
    2022-04-04
  • vue項目頁面嵌入代碼塊vue-prism-editor的實現(xiàn)

    vue項目頁面嵌入代碼塊vue-prism-editor的實現(xiàn)

    這篇文章主要介紹了vue項目頁面嵌入代碼塊vue-prism-editor的實現(xiàn),本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-10-10
  • vue實現(xiàn)的組件兄弟間通信功能示例

    vue實現(xiàn)的組件兄弟間通信功能示例

    這篇文章主要介紹了vue實現(xiàn)的組件兄弟間通信功能,結(jié)合實例形式分析了vue兄弟組件間通信的原理與相關(guān)操作技巧,需要的朋友可以參考下
    2018-12-12

最新評論