1、onMounted()
onMounted() 会在组件挂载到 DOM 后立即调用,此时 DOM 已经渲染完毕,可以进行相关的 DOM 操作或发起网络请求。
export default {
setup() {
// 可以在这里定义响应式状态、计算属性等
onMounted(() => {
// 组件挂载到 DOM 后执行的代码
console.log('组件已挂载到 DOM');
// 在这里可以进行 DOM 操作或发起网络请求等
});
// 返回需要暴露给模板的响应式状态或方法等
return {
// ...
};
},
};
2、onUpdated()
在组件因为响应式状态变更而更新其 DOM 树之后调用。
<script setup>
import { ref, onUpdated } from 'vue'
const count = ref(0)
onUpdated(() => {
// 文本内容应该与当前的 `count.value` 一致
console.log(document.getElementById('count').textContent)
})
</script>
<template>
<button id="count" @click="count++">{{ count }}</button>
</template>
3、onUnmounted()
在组件实例被卸载之后调用。这个钩子在服务器端渲染期间不会被调用。
一个组件在以下情况下被视为已卸载:
- 其所有子组件都已经被卸载。
- 所有相关的响应式作用 (渲染作用以及 setup() 时创建的计算属性和侦听器) 都已经停止。
可以在这个钩子中手动清理一些副作用,例如计时器、DOM 事件监听器或者与服务器的连接。
<script setup>
import { onMounted, onUnmounted } from 'vue'
let intervalId
onMounted(() => {
intervalId = setInterval(() => {
// ...
})
})
onUnmounted(() => clearInterval(intervalId))
</script>
4、onBeforeMount()
在组件被挂载之前被调用。这个钩子在服务器端渲染期间不会被调用。
当这个钩子被调用时,组件已经完成了其响应式状态的设置,但还没有创建 DOM 节点。它即将首次执行 DOM 渲染过程。
5、onBeforeUpdate()
这个钩子在服务器端渲染期间不会被调用。
在组件即将因为响应式状态变更而更新其 DOM 树之前调用。
这个钩子可以用来在 Vue 更新 DOM 之前访问 DOM 状态。在这个钩子中更改状态也是安全的。
6、onBeforeUnmount()
在组件实例被卸载之前调用。这个钩子在服务器端渲染期间不会被调用。
当这个钩子被调用时,组件实例依然还保有全部的功能。
7、onErrorCaptured()
在捕获了后代组件传递的错误时调用。
错误可以从以下几个来源中捕获:
- 组件渲染
- 事件处理器
- 生命周期钩子
- setup() 函数
- 侦听器
- 自定义指令钩子
- 过渡钩子
8、onRenderTracked() --仅开发阶段
当组件渲染过程中追踪到响应式依赖时调用。这个钩子仅在开发模式下可用,且在服务器端渲染期间不会被调用。
9、onRenderTriggered() --仅开发阶段
当响应式依赖的变更触发了组件渲染时调用。这个钩子仅在开发模式下可用,且在服务器端渲染期间不会被调用。
10、onActivated()
若组件实例是 <KeepAlive> 缓存树的一部分,当组件被插入到 DOM 中时调用。
这个钩子在服务器端渲染期间不会被调用。
11、onDeactivated()
组件实例是 缓存树的一部分,当组件从 DOM 中被移除时调用。
这个钩子在服务器端渲染期间不会被调用。
12、onServerPrefetch() --仅服务端渲染使用
在组件实例在服务器上被渲染之前调用。
- 如果这个钩子返回了一个 Promise,服务端渲染会在渲染该组件前等待该 Promise 完成。
- 这个钩子仅会在服务端渲染中执行,可以用于执行一些仅存在于服务端的数据抓取过程。
<script setup>
import { ref, onServerPrefetch, onMounted } from 'vue'
const data = ref(null)
onServerPrefetch(async () => {
// 组件作为初始请求的一部分被渲染
// 在服务器上预抓取数据,因为它比在客户端上更快。
data.value = await fetchOnServer(/* ... */)
})
onMounted(async () => {
if (!data.value) {
// 如果数据在挂载时为空值,这意味着该组件
// 是在客户端动态渲染的。将转而执行
// 另一个客户端侧的抓取请求
data.value = await fetchOnClient(/* ... */)
}
})
</script>