Vue.js组件生命周期包括创建、挂载、更新和销毁阶段。在这些阶段中,Vue提供了一系列的生命周期钩子函数,开发者可以在这些钩子函数中执行自定义的逻辑。以下是Vue组件生命周期钩子函数及其触发时机:
创建阶段(Creation)
beforeCreate
:- 触发时机:在实例刚被创建时,数据观测和事件/生命周期事件的配置之前被调用。
- 用途:在这个阶段,实例的数据观测和初始化还未开始。
created
:- 触发时机:在实例已经创建完成之后调用,此时实例已经完成数据观测、属性和方法的运算,但尚未挂载到DOM上。
- 用途:在这个阶段,可以进行异步操作,如发起网络请求等。
挂载阶段(Mounting)
beforeMount
:- 触发时机:在挂载开始之前被调用,即在 render 函数被调用之前。
- 用途:在这个阶段,可以进行一些修改模板的操作。
mounted
:- 触发时机:在实例挂载之后调用。
- 用途:在这个阶段,可以访问DOM元素,并且可以进行DOM操作。
更新阶段(Updating)
beforeUpdate
:- 触发时机:在数据更新之前被调用,发生在虚拟DOM重新渲染和打补丁之前。
- 用途:在这个阶段,可以进行一些更新前的操作。
updated
:- 触发时机:在数据更改导致的虚拟DOM重新渲染和打补丁之后调用。
- 用途:在这个阶段,可以进行一些DOM操作。
销毁阶段(Destroying)
beforeDestroy
:- 触发时机:在实例销毁之前调用。在这一步,实例仍然完全可用。
- 用途:在这个阶段,可以进行一些清理工作,如清除定时器、取消订阅等。
destroyed
:- 触发时机:在实例销毁之后调用。在这一步,Vue实例的所有指令和事件监听器都被解绑,所有子实例被销毁。
- 用途:在这个阶段,进行最终的清理工作,释放资源。
错误捕获阶段(Error Capturing)
errorCaptured
:- 触发时机:当子组件抛出错误时,会向上冒泡触发父组件的 errorCaptured 钩子。仅在 2.4.0+ 版本可用。
- 用途:用于处理子组件抛出的错误,阻止错误继续向上传播。
这些生命周期钩子函数提供了在组件生命周期不同阶段执行自定义逻辑的机会,开发者可以根据业务需求在合适的时机进行操作。