一、什么是生命周期
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的行为未定义。