欢迎来到代码驿站!

vue

当前位置:首页 > 网页前端 > vue

vue源码之首次渲染过程详解

时间:2022-07-15 08:36:09|栏目:vue|点击:

首次渲染

src/core/instance/index.js 中的 this._init方法

在这里插入图片描述

init方法内部

在这里插入图片描述
在这里插入图片描述

$mount内部 - 编译版本内部逻辑

在这里插入图片描述

$mount内部 - 运行时版本内部逻辑(最终执行) runtime/index中的 $mount方法

进入runtime/index中的$mount方法可以看到最终调用了mountComponent函数来渲染dom

core/instance/lifecycle 中的mountComponent

在这里插入图片描述

src/core/observer/watcher

在这里插入图片描述

在这里插入图片描述

总结

首次渲染过程

  • vue初始化 实例成员 静态成员
  • new Vue()
  • this._init()
  • vm.$mount() - src/platforms/web/entry-runtime-with-compiler.js
    • 如果没有传递render,把模版编译成render函数
    • compileToFunctions()生成render()渲染函数
    • options.render = render
  • vm.$mount() runtime/index中定义的 $mount 最终调用了mountComponent函数
  • mountComponent(this,el) - src/core/instance/lifecycle.js
    • 判断是否有render选项,如果没有但是传入了模版,并且当前是开发环境的话会发送警告
    • 触发beforeMount
    • 定义 updateComponent
    • 创建watcher实例
    • 触发mounted
    • return vm
  • watcher.get()
    • 创建完watcher之后会调用一次get
    • 调用updateComponent函数
    • 调用 vm._render函数创建VNode
      • 调用render.call(vm._renderProxy, vm.$createElement)
      • 调用实例化时vue传入的render 函数
      • 或者编译template生成的render
      • 返回vnode
    • 调用vm._update内部调用vm.__patch__方法挂载真实dom 记录 vm.$el

总结

上一篇:vuex刷新之后数据丢失,数据持久化,vuex-persistedstate问题

栏    目:vue

下一篇:Vue中点击url下载文件的案例详解

本文标题:vue源码之首次渲染过程详解

本文地址:http://www.codeinn.net/misctech/207860.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有