【Vue2 ✨】Vue2 入门之旅(四):生命周期钩子

前三篇我们学习了 Vue 的基础、模板语法和数据相关知识。本篇将介绍 Vue2 的 生命周期钩子,理解组件从"出生"到"销毁"的全过程。


目录

  1. 什么是生命周期
  2. 生命周期流程图
  3. 常见生命周期钩子
  4. 使用场景
  5. 小结

什么是生命周期

Vue 实例从创建到销毁,会经历一系列过程:

  • 初始化数据
  • 挂载 DOM
  • 更新数据
  • 卸载组件

在这些关键时刻,Vue 会触发 生命周期钩子函数,让开发者在合适的时机执行逻辑。


生命周期流程图

Vue2 生命周期大致流程如下:

复制代码
beforeCreate -> created -> beforeMount -> mounted -> beforeUpdate -> updated -> beforeDestroy -> destroyed

常见生命周期钩子

beforeCreate

组件实例刚创建,还没有 datamethods

适合做一些低级初始化。

js 复制代码
beforeCreate() {
  console.log('组件刚创建,还没有数据')
}

created

实例已经创建好,data 已经初始化完成。

可以进行 数据请求、定时器设置等。

js 复制代码
created() {
  console.log('组件创建完成,可以访问 data:', this.title)
  // this.fetchData()
}

beforeMount

模板编译完成,但尚未挂载到 DOM。

js 复制代码
beforeMount() {
  console.log('模板已编译,但还没挂载到页面')
}

mounted

组件挂载完成,可以操作 DOM。

js 复制代码
mounted() {
  console.log('组件挂载完成,可以操作 DOM')
  const el = this.$el.querySelector('p')
  console.log(el.innerText)
}

beforeUpdate

数据即将更新,界面还没刷新。

js 复制代码
beforeUpdate() {
  console.log('数据即将更新')
}

updated

数据更新完成,界面已重新渲染。

js 复制代码
updated() {
  console.log('页面更新完成')
}

beforeDestroy

实例即将销毁。

适合清除定时器、解绑事件。

js 复制代码
beforeDestroy() {
  console.log('组件即将销毁')
  clearInterval(this.timer)
}

destroyed

实例销毁完成,所有绑定解除。

js 复制代码
destroyed() {
  console.log('组件已销毁')
}

使用场景

  • created:发送请求、初始化数据
  • mounted:操作 DOM、第三方库初始化
  • beforeDestroy:资源回收,清除定时器、事件解绑

小结

  1. Vue 生命周期包含 创建 → 挂载 → 更新 → 销毁 四个阶段。
  2. 常见钩子:
    • created:数据就绪,可以发请求
    • mounted:DOM 已挂载,可以操作界面
    • beforeDestroy:做清理工作
  3. 正确利用生命周期钩子,可以让代码更加清晰、职责分明。

📚 下一篇文章,我们将学习 组件化开发,深入理解 Vue 的模块化思想。

相关推荐
swipe6 小时前
正则表达式入门到进阶:从表单校验到手写模板引擎
前端·javascript·面试
kyriewen7 小时前
前端错误监控最全指南:捕获 JS 异常、Promise 拒绝、资源加载失败,附上报代码
前端·javascript·监控
大家的林语冰7 小时前
ESLint 近期动态大全,新版本正式发布,antfu 大佬推荐的插件也更新了!
前端·javascript·前端工程化
胡志辉8 小时前
深入浅出 call、apply、bind
前端·javascript·后端
十九画生11 小时前
parentID ``` JavaScript 是区分大小写的,所以这两个不是同一个字段。 第二,`parent` 没有声明。 应该先写: `
javascript
怕浪猫11 小时前
Electron 开发实战(十六):总结与展望|生态现状、框架对比、行业趋势与学习指南
前端·javascript·electron
ZengLiangYi12 小时前
批量导入 1000 条对话的性能优化实战
javascript·后端·架构
竹林81812 小时前
用 wagmi v2 + viem 监听合约事件时踩的坑,我花了两天才把"遗漏事件"修好
javascript
小花酱酱13 小时前
QQ群里只有你一个人?邪门歪道破局之路——AstrBot
javascript
bonechips13 小时前
JS 数组指南:从内存原理到二维矩阵
前端·javascript