Vue生命周期(简单易懂,超详细)

一、什么是生命周期

1.一句话概括:组件从创建到销毁的整个过程就是生命周期

2.作用:特定的时间点,执行特定的操作

3.使用场景:组件创建完毕后,可以在created 生命周期函数中发起Ajax 请求,从而初始化 data 数据

二、钩子函数

1.创建期间的生命周期函数

(1)beforeCreate(初始化界面前):

        ①实例刚在内存中被创建出来,此时,还没有初始化好 data 和 methods 属性

        ②一般用于加loading事件

(2)created(初始化界面后):

        ①实例已经在内存中创建OK,此时 data 和 methods 已经创建OK,此时还没有开始 编译模板

        ②一般用于结束loading、请求数据为mounted渲染做准备

2.挂载期间的生命周期函数

(1)beforeMount(渲染DOM前)

        此时已经完成了模板的编译,但是还没有挂载到页面中

(2)mounted(渲染DOM后)

        ①此时,已经将编译好的模板,挂载到了页面指定的容器中显示

        ②一般用于配合路由钩子使用

3. 运行期间的生命周期函数

(1)beforeUpdate(更新数据前):

        状态更新之前执行此函数, 此时 data 中的状态值是最新的,但是界面上显示的 数据还是旧的,因为此时还没有开始重新渲染DOM节点

(2)updated(更新数据后):

        ①实例更新完毕之后调用此函数,此时 data 中的状态值 和 界面上显示的数据,都已经完成了更新,界面已经被重新渲染好了!

        ②一般用于数据更新时,做一些处理(此处也可以用watch进行观测)

3.销毁期间的生命周期函数

(1)beforeDestroy(卸载组件前):

        实例销毁之前调用。在这一步,实例仍然完全可用。

(2)destroyed(卸载组建后):

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

        ②一般用于组件销毁时进行提示

三、钩子函数的理解

所有的生命周期钩子自动绑定this上下文到实例中,因此你可以访问数据,对属性和方法进行运算。这意味着你不能使用箭头函数来定义一个生命周期方法(例如created: () => this.fetchTodos())。这是因为箭头函数绑定了父上下文,因此this与你期待的 Vue 实例不同,this.fetchTodos的行为未定义。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值