全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Vue之Watcher源码解析(2)

接着上节Vue Watcher源码的话,继续探讨,目前是这么个过程:

函数大概是这里:

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

    // 获取参数

    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)) {
      // 返回空节点
    }
    // set parent
    vnode.parent = _parentVnode;
    return vnode
  };

然后,在上个月,我卡死在了render.call这个函数上面,因为所有vue实例被设置了proxy代理,所以会跳转到各种奇怪的检测函数中。

过了一个月,我依然看不懂,一点都不想讲,所以先跳过,直接看后面!

这里假设vnode已经返回了,来看看是个啥:

这是一个虚拟节点,由之前字符串化后的DOM树生成,主要包含子节点、上下文、属性、文本、标签名、类型等属性,这些可以直接从键名判断。

得到vnode后,由于这里是根节点,所以不存在_parentVnode,直接返回。

然后到了mountComponent函数:

// 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() {
        // 开发者模式下的处理方式
      };
    } 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函数,开始正式渲染页面。

函数如下:

// 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.
  };

由于是初次渲染,所以会进入第一个条件分支,并调用__patch__函数,传入原生DOM节点、虚拟DOM、false三个参数。

__patch__在加载框架时候已经注入了,见代码:

  // 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为属性、指令等相关方法。

这个createPatchFunction函数的构造相当于一个模块,里面包含大量的方法,但是最后不是返回一个对象包含内部方法的引用,而是返回一个函数,形式大概如下:

 // line-4762
  function createPatchFunction() {
    // fn1...
    // fn2...
    return function patch() {
      // 调用内部方法fn1,fn2...
    }
  }

方法比较多,下次再讲,边跑流程边看。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# Vue  # Watcher  # vue如何实现observer和watcher源码解析  # 简单实现Vue的observer和watcher  # Vue之Watcher源码解析(1)  # 死在  # 是个  # 带着  # 过了  # 第一个  # 一个月  # 这是一个  # 不存在  # 来看看  # 可以直接  # 大概是  # 比较多  # 在上  # 看不懂  # 个月  # 边看  # 跳过  # 大家多多  # 看后  # 高阶 


相关文章: 安云自助建站系统如何快速提升SEO排名?  建站IDE高效指南:快速搭建+SEO优化+自适应模板全解析  无锡营销型网站制作公司,无锡网选车牌流程?  如何在万网自助建站中设置域名及备案?  建站之星免费版是否永久可用?  网站制作网站,深圳做网站哪家比较好?  ,怎么用自己头像做动态表情包?  沈阳个人网站制作公司,哪个网站能考到沈阳事业编招聘的信息?  如何在建站主机中优化服务器配置?  网站制作专业公司有哪些,如何制作一个企业网站,建设网站的基本步骤有哪些?  常州企业网站制作公司,全国继续教育网怎么登录?  魔毅自助建站系统:模板定制与SEO优化一键生成指南  如何快速生成橙子建站落地页链接?  免费公司网站制作软件,如何申请免费主页空间做自己的网站?  如何通过WDCP绑定主域名及创建子域名站点?  如何在景安服务器上快速搭建个人网站?  已有域名和空间,如何快速搭建网站?  seo网站制作优化,网站SEO优化步骤有哪些?  如何在服务器上配置二级域名建站?  制作网站的基本流程,设计网站的软件是什么?  logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?  如何配置FTP站点权限与安全设置?  c# 在高并发下使用反射发射(Reflection.Emit)的性能  建站之星各版本价格是多少?  PHP 500报错的快速解决方法  专业网站制作服务公司,有哪些网站可以免费发布招聘信息?  宿州网站制作公司兴策,安徽省低保查询网站?  移民网站制作流程,怎么看加拿大移民官网?  已有域名如何免费搭建网站?  建站主机服务器选型指南与性能优化方案解析  台州网站建设制作公司,浙江手机无犯罪记录证明怎么开?  如何在IIS中配置站点IP、端口及主机头?  高防服务器租用如何选择配置与防御等级?  公司网站制作需要多少钱,找人做公司网站需要多少钱?  制作网站公司那家好,网络公司是做什么的?  建站之星微信建站一键生成小程序+多端营销系统  网站制作新手教程,新手建设一个网站需要注意些什么?  建站org新手必看:2024最新搭建流程与模板选择技巧  专业商城网站制作公司有哪些,pi商城官网是哪个?  如何通过VPS建站无需域名直接访问?  武汉网站制作费用多少,在武汉武昌,建面100平方左右的房子,想装暖气片,费用大概是多少啊?  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  黑客如何通过漏洞一步步攻陷网站服务器?  如何在Ubuntu系统下快速搭建WordPress个人网站?  寿县云建站:智能SEO优化与多行业模板快速上线指南  如何选择高效可靠的多用户建站源码资源?  建站之星3.0如何解决常见操作问题?  如何用wdcp快速搭建高效网站?  广州美橙建站如何快速搭建多端合一网站?  建站之星安装后如何配置SEO及设计样式? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。