Vue学习笔记(2)—— Vue的生命周期

本文深入探讨Vue的生命周期,包括beforeCreate、created、beforeMount、mounted、beforeUpdate、updated、beforeDestroy和destroyed八个阶段,解释各阶段的特点及应用场景,帮助读者全面理解Vue组件的生命周期。

(转自优快云)面试碰到这个问题了,回想一下,很多问题都是写代码的时候碰到了随查随写缺少总结,真到了要说点什么的时候就说的乱七八糟,那么这次就来捋一捋Vue的生命周期

生命周期,就是Vue实例在被创建之前要经过一系列的初始化过程。首先,放一张Vue官网的生命周期图示。
图示中可以看到,Vue的生命周期中顺序的包含了以下几个生命周期钩子,然后结合生命周期我们逐一讨论:

  • beforeCreate
  • created
  • beforeMount
  • mounted
  • beforeUpdate
  • updated
  • beforeDestroy
  • destroyed
1. beforeCreate

在这个生命周期,组件实例刚刚被创建但尚未创建完成,而组件属性如$eldata等都还没有计算。

2. created

组件实例已创建完成,data等属性已绑定完成,但DOM尚未生成,$el 属性还不存在

3. beforeMount

即模板编译、挂载之前,这个生命周期,首先会判断是否存在el选项,存在则继续编译,否则停止编译、生命周期暂停直到调用vm.$mount(el)方法才会继续向下编译,这个el参数就是挂载的DOM节点。 接下来会判断是否存在template选项,存在则将其作为模板编译成render函数,否则将el的外部HTML作为模板编译。
另外vue对象中存在一个render函数,它的优先级大于template。

4. mounted

即模板编译、挂载之后,这里会给vue实例对象添加$el成员,并且替换掉挂载的DOM元素。举例而言,我们写在页面的<div>{{msg}}</div>是在这里把实例里的msg值渲染上去的。

5. beforeUpdate

data的数据发生改变时,会触发对应组件的重新渲染,这时可以检测到data变化但是view还没有重新渲染。

6. updated

view层被重新渲染,数据更新。

6. beforeDestroy

beforeDestroy在实例被销毁之前,这时实例仍然完全可用。

7. destroyed

destroyed 在实例被销毁之后,Vue 实例指示的所有东西都会解绑定,所有的事件监听器会被移除,所有的子实例也会被销毁。


生命周期就讨论到这里了,觉得比较抽象的盆友可以自己写demo测试一下,会更直观一些,或者参考一下更详细的文章把。

参考文章:

Vue2.0 探索之路——生命周期和钩子函数的一些理解
Vue官网文档
详解vue生命周期

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值