组件的创建与挂载

#创建顺序(以el-form表单为例)

复制代码
// 你的模板
<el-form ref="formRef" :model="form" :rules="rules">
  <el-form-item label="用户名" prop="username">
    <el-input v-model="form.username" />
  </el-form-item>
  <el-form-item label="密码" prop="password">
    <el-input v-model="form.password" type="password" />
  </el-form-item>
</el-form>

// 对应的虚拟 DOM 树
{
  type: 'el-form',
  props: { model: form, rules: rules },
  children: [
    {
      type: 'el-form-item',
      props: { label: '用户名', prop: 'username' },
      children: [{ type: 'el-input', props: { modelValue: form.username } }]
    },
    {
      type: 'el-form-item', 
      props: { label: '密码', prop: 'password' },
      children: [{ type: 'el-input', props: { modelValue: form.password, type: 'password' } }]
    }
  ]
}

// 组件创建顺序(从父到子):

created (form) → created (form-item) → created (input)

#挂载顺序

复制代码
一次性转换为真实DOM                                  
│    <form class="el-form"> (真实)                        
│    ├── <div class="el-form-item"> (真实)                
│    │   └── <div class="el-input"> (真实)                
│    └── <div class="el-form-item"> (真实)                
│        └── <div class="el-input"> (真实)    

mounted (input) → mounted (form-item) → mounted (form)

// 注意:子组件先 mounted,父组件后 mounted

相关推荐
我叫Double4 小时前
GeneralAdmin-3
前端·javascript·vue.js
json{shen:"jing"}4 小时前
10_自定义事件组件交互
开发语言·前端·javascript
Jinuss4 小时前
源码分析之React中scheduleUpdateOnFiber调度更新解析
前端·javascript·react.js
一位搞嵌入式的 genius4 小时前
深入理解 JavaScript 异步编程:从 Event Loop 到 Promise
开发语言·前端·javascript
brevity_souls4 小时前
SQL Server 窗口函数简介
开发语言·javascript·数据库
走粥4 小时前
选项式API与组合式API的区别
开发语言·前端·javascript·vue.js·前端框架
晚霞的不甘5 小时前
解决 Flutter for OpenHarmony 构建失败:HVigor ERROR 00303168 (SDK component missing)
android·javascript·flutter
2501_944521595 小时前
Flutter for OpenHarmony 微动漫App实战:分享功能实现
android·开发语言·javascript·flutter·ecmascript
小小码农Come on5 小时前
QPushButton QSS(一):按钮常用qss
前端·javascript·css·qt5
Booksort5 小时前
React+js环境配置(极速版)
前端·javascript·react.js