news 2026/6/15 18:54:44

请描述下你对 Vue 生命周期的理解?在 `created` 和 `mounted` 中请求数据有什么区别?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
请描述下你对 Vue 生命周期的理解?在 `created` 和 `mounted` 中请求数据有什么区别?


一、什么是 Vue 生命周期?

Vue 生命周期指的是一个组件实例从创建到销毁的全过程。在这个过程中,Vue 会自动执行一系列初始化操作(如数据观测、模板编译、DOM 挂载等),并在特定阶段触发生命周期钩子函数,允许开发者在这些时机插入自定义逻辑。

就像一条流水线:每个“工人”(钩子)在任务流经自己岗位时执行特定工作。

⚠️ 注意:所有生命周期钩子的this都自动绑定到当前 Vue 实例,因此不能使用箭头函数(否则this会指向外层作用域)。


二、Vue 的 8 个核心生命周期钩子

钩子触发时机典型用途
beforeCreate实例刚被创建,datamethods等尚未初始化插件开发中做极早期初始化
created实例已完成数据观测、属性/方法初始化,但 DOM 未生成发起异步请求、初始化非 DOM 相关逻辑
beforeMount模板已编译为 render 函数,虚拟 DOM 已创建,真实 DOM 未挂载可访问$el(原始挂载点),但内容未替换
mounted真实 DOM 已挂载并渲染完成操作 DOM、初始化第三方库(如 echarts)、获取元素尺寸
beforeUpdate数据变化后,虚拟 DOM 重新渲染前获取更新前的状态
updated虚拟 DOM 重新渲染并真实 DOM 更新后执行依赖 DOM 更新后的操作(慎用,避免无限循环)
beforeDestroy实例销毁前,仍可访问所有属性和方法清理定时器、取消订阅、解绑事件
destroyed实例完全销毁,仅保留 DOM 节点(不会自动移除)彻底释放资源

📌 补充(带keep-alive时):

  • activated:缓存组件被激活时调用
  • deactivated:缓存组件被停用时调用

三、createdvsmounted:请求数据的区别

这是面试高频考点!核心区别在于DOM 是否就绪

✅ 相同点:

  • 都能访问thisdatamethodscomputed等;
  • 都可以发起 AJAX 请求获取数据。

❗ 关键区别:

维度createdmounted
触发时机实例创建完成,早于 DOM 渲染DOM 已挂载并渲染完成
能否操作 DOM❌ 不能($el为原始挂载点或 undefined)✅ 可以($el是最终渲染的 DOM)
用户体验数据在页面渲染前加载,无闪动若数据较慢,可能先看到空白/默认 UI,再更新 →可能出现“闪屏”
适用场景推荐用于大多数数据请求(尤其不影响 DOM 结构的数据)适用于必须等 DOM 存在才能发起的请求(极少见),或需结合 DOM 尺寸计算的场景

🎯 最佳实践建议:

  • 优先在created中请求数据
    因为它更早执行,能让数据在页面渲染前就位,避免用户看到“加载中”或空白状态。
  • 除非你需要 DOM 信息(比如根据容器宽高请求不同尺寸的图片),否则不要等到mounted再发请求。

💡 举例:
如果你在mounted中请求用户信息,而模板中有{{ userInfo.name }},那么页面会先显示空值(或默认值),等请求回来才更新——这就是“闪动”。
而在created中请求,配合v-if="userInfo",就能实现“数据准备好才渲染”,体验更流畅。


四、总结

  • Vue 生命周期是理解组件行为的核心,每个钩子都有其明确职责;
  • created数据准备的最佳时机mountedDOM 操作的安全时机
  • 数据请求应尽量前置到created,以提升首屏体验,避免不必要的 UI 闪烁。

这也是为什么 Vue 官方文档和社区普遍推荐:“能用 created,就不用 mounted 发请求”


参考文献

  • 掘金:Vue 生命周期详解
  • Vue.js 官方文档
  • 百度百科:生命周期概念


版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/13 5:33:13

2025最新!8个AI论文软件测评:研究生写论文痛点全解析

2025最新!8个AI论文软件测评:研究生写论文痛点全解析 2025年AI论文写作工具测评:精准解决研究生写作难题 随着人工智能技术的不断进步,AI论文写作工具逐渐成为研究生群体提升效率、优化内容的重要助手。然而,面对市场…

作者头像 李华
网站建设 2026/6/15 18:06:54

基于微信小程序的家政服务与互助平台系统毕设源码+文档+讲解视频

前言 本课题聚焦居家服务领域供需失衡与邻里信任缺失问题,设计开发基于微信小程序的家政服务与互助一体化平台。平台依托微信生态的高普及率与便捷性,整合专业家政服务与邻里互助两大核心场景,涵盖保洁、育儿、维修等专业服务的精准匹配&…

作者头像 李华
网站建设 2026/6/15 15:46:49

LeetCode热题--322. 零钱兑换--中等

题目 给你一个整数数组 coins ,表示不同面额的硬币;以及一个整数 amount ,表示总金额。 计算并返回可以凑成总金额所需的 最少的硬币个数 。如果没有任何一种硬币组合能组成总金额,返回 -1 。 你可以认为每种硬币的数量是无限的…

作者头像 李华
网站建设 2026/6/15 15:52:45

9个AI论文工具推荐,研究生轻松搞定学术写作!

9个AI论文工具推荐,研究生轻松搞定学术写作! AI工具如何助力研究生高效完成学术写作 随着人工智能技术的不断进步,越来越多的研究生开始借助AI工具来提升论文写作的效率与质量。在当前的学术环境中,AI工具不仅能够帮助学生快速生成…

作者头像 李华
网站建设 2026/6/15 18:08:12

AI助力学术写作:9款工具实测,开题报告+降重功能全面解析

AI写论文平台排名:9个实测,开题报告论文降重都好用工具对比排名表格工具名称核心功能突出优势Aibiye降AIGC率适配高校规则,AI痕迹弱化Aicheck论文降重速度快,保留专业术语Askpaper论文降重逻辑完整性好秘塔写作猫智能降重结合语法…

作者头像 李华