当前位置: 首页 > news >正文

vue2初始化过程

Vue2 的初始化过程主要包括以下几个核心步骤:

1. 初始化流程概述

// Vue 构造函数
function Vue(options) {this._init(options)
}

2. 初始化阶段

2.1 _init() 方法

Vue.prototype._init = function(options) {const vm = this// 合并配置if (options && options._isComponent) {// 组件配置合并initInternalComponent(vm, options)} else {vm.$options = mergeOptions(resolveConstructorOptions(vm.constructor),options || {},vm)}// 初始化生命周期、事件、渲染等initLifecycle(vm)        // 初始化生命周期initEvents(vm)           // 初始化事件initRender(vm)           // 初始化渲染callHook(vm, 'beforeCreate') // 调用 beforeCreate 钩子initInjections(vm)       // 初始化注入initState(vm)            // 初始化状态(核心)initProvide(vm)          // 初始化提供callHook(vm, 'created')  // 调用 created 钩子// 挂载if (vm.$options.el) {vm.$mount(vm.$options.el)}
}

2.2 初始化状态 (initState)

function initState(vm) {vm._watchers = []const opts = vm.$optionsif (opts.props) initProps(vm, opts.props)if (opts.methods) initMethods(vm, opts.methods)if (opts.data) {initData(vm)           // 初始化 data,进行响应式处理} else {observe(vm._data = {}, true)}if (opts.computed) initComputed(vm, opts.computed)if (opts.watch) initWatch(vm, opts.watch)
}

2.3 响应式系统初始化

function initData(vm) {let data = vm.$options.datadata = vm._data = typeof data === 'function' ? getData(data, vm) : data || {}// 代理 data 到 vm 实例上const keys = Object.keys(data)let i = keys.lengthwhile (i--) {proxy(vm, '_data', keys[i])}// 观察数据observe(data, true)
}

3. 挂载阶段

3.1 $mount 方法

Vue.prototype.$mount = function(el, hydrating) {el = el && query(el)const options = this.$options// 解析 template/el 为 render 函数if (!options.render) {let template = options.templateif (template) {// 编译模板const { render, staticRenderFns } = compileToFunctions(template,{...})options.render = renderoptions.staticRenderFns = staticRenderFns}}return mount.call(this, el, hydrating)
}

4. 完整的初始化流程总结

  1. 合并配置:合并构造函数选项和实例选项
  2. 初始化生命周期:建立组件关系,初始化 $parent、$children 等
  3. 初始化事件:处理父组件传递的事件
  4. 初始化渲染:创建 $slots、$scopedSlots,定义 $createElement
  5. 调用 beforeCreate 钩子
  6. 初始化注入:处理 inject 选项
  7. 初始化状态(核心步骤):
    • 初始化 props
    • 初始化 methods
    • 初始化 data(响应式处理)
    • 初始化 computed
    • 初始化 watch
  8. 初始化提供:处理 provide 选项
  9. 调用 created 钩子
  10. 挂载:如果存在 el 选项,自动调用 $mount 方法

这个过程建立了 Vue 实例的响应式系统,为后续的数据变化侦测和视图更新奠定了基础。

http://www.jsqmd.com/news/12879/

相关文章:

  • [Doris/函数] Doris 之数据查询
  • 如何用AI绘制程序时序图
  • LLVM 后端支持 RISCV 矩阵扩展都有哪些方式
  • upload的典型案例demo
  • # 这个函数对i1进行正则拆分, 返回列表. 跟re.split区别是他保留分隔符.
  • 简单聊聊数据可视化大屏制作的前端设计与后端开发
  • 详细介绍:PPT auto Crorrector
  • [THUWC 2018] 字胡串
  • 2025 年钢结构厂家推荐榜:箱型H型/厂房仓库/电厂/桥梁/农牧业/锅炉/场馆/高层框架/装配式钢结构工厂,聚焦安全与品质,助力建筑项目精准选品
  • 2025 年粮库空调厂家最新推荐榜:聚焦技术创新与实用适配,助力粮库精准选购优质设备粮库空调一体机/粮库空调机组/碳钢喷塑粮库空调/低温粮库空调厂家推荐
  • 2025 年最新推荐!泳池除湿热泵厂家推荐榜单重磅发布,全方位解析优质厂家实力助您选对设备双模式/多功能/三集一体/全直流变频/室内/变频式泳池除湿热泵厂家推荐
  • django template filter safe escapejs json_script等
  • 2025年GEO(AI搜索优化)厂家口碑推荐排行榜
  • 2025年GEO(AI搜索优化)源头厂家权威推荐榜单:云视有客科技领跑行业新纪元
  • 2025年GEO服务商口碑推荐榜单:顶尖AI搜索优化厂家全方位解析
  • 2025年GEO(AI搜索优化)厂家口碑推荐榜:云视有客科技领跑行业创新
  • 2025企业聊天软件排行 5款好用的通讯软件推荐
  • 【触想智能】工业安卓一体机在人工智能领域上的市场应用分析
  • Redis中的线程模型 - 浪矢
  • 2025 年油气回收设备厂家最新推荐排行榜:加油站 / 油库 / 码头 / 化工厂适用优质品牌精选
  • Vue3 + OpenLayers + 天地图 简单集成
  • 基于 PyTorch 完全从零手搓 GPT 混合专家 (MOE) 对话模型 - 详解
  • Linux环境下安装Jenkins2.346.3
  • 2025 年疲劳试验机厂家最新推荐排行榜:涵盖液压 / 电动 / 扭转等多类型设备,助力企业精准挑选优质厂家
  • 2025 年万能试验机厂家最新推荐排行榜:涵盖电子 / 液压 / 拉力 / 压力 / 冲击等类型,助力企业科研机构精准选购优质设备
  • 2025 年涡流分离器源头厂家最新推荐排行榜:聚焦国内优质企业,助力制造企业精准采购可靠分离设备旋转分配器/油路分配器/离心过滤器厂家推荐
  • 欧美(美股、加拿大股票、墨西哥股票)股票数据接口文档
  • 2025年GEO(AI搜索优化)服务商口碑排行榜
  • 为了这0.1 dB,他在实验室蹲了整整8年
  • vue播放rtsp流方案