组件的创建与挂载

#创建顺序(以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

相关推荐
要加油哦~10 小时前
AI | 实践教程 - ScreenCoder | 多agents前端代码生成
前端·javascript·人工智能
一个public的class10 小时前
你在浏览器输入一个网址,到底发生了什么?
java·开发语言·javascript
青茶36011 小时前
php怎么实现订单接口状态轮询请求
前端·javascript·php
火车叼位11 小时前
脚本伪装:让 Python 与 Node.js 像原生 Shell 命令一样运行
运维·javascript·python
VT.馒头11 小时前
【力扣】2727. 判断对象是否为空
javascript·数据结构·算法·leetcode·职场和发展
发现一只大呆瓜11 小时前
虚拟列表:从定高到动态高度的 Vue 3 & React 满分实现
前端·vue.js·react.js
鱼毓屿御12 小时前
如何给用户添加权限
前端·javascript·vue.js
JustHappy12 小时前
「web extensions🛠️」有关浏览器扩展,开发前你需要知道一些......
前端·javascript·开源
xixixin_12 小时前
【JavaScript 】从 || 到??:JavaScript 空值处理的最佳实践升级
开发语言·javascript·ecmascript
Java新手村12 小时前
基于 Vue 3 + Spring Boot 3 的 AI 面试辅助系统:实时语音识别 + 大模型智能回答
vue.js·人工智能·spring boot