callOnce
在 SSR 或 CSR 期间,运行给定的函数或代码块一次。
此实用程序自 Nuxt v3.9 可用。
目的
callOnce
函数旨在在以下情况下仅执行给定的函数或代码块一次:
- 服务器端渲染,但不包括水合作用
- 客户端导航
这对于只应执行一次的代码很有用,例如记录事件或设置全局状态。
用法
app.vue
<script setup lang="ts">
const websiteConfig = useState('config')
await callOnce(async () => {
console.log('This will only be logged once')
websiteConfig.value = await $fetch('https://my-cms.com/api/website-config')
})
</script>
callOnce
是一个组合式函数,旨在直接在 setup 函数、插件或路由中间件中调用,因为它需要将数据添加到 Nuxt 有效负载中,以避免在页面水合时在客户端重新调用该函数。类型
callOnce(fn?: () => any | Promise<any>): Promise<void>
callOnce(key: string, fn?: () => any | Promise<any>): Promise<void>
key
:一个唯一的键,确保代码只运行一次。如果你不提供键,则会为你生成一个对于callOnce
实例的文件和行号唯一的键。fn
:要运行一次的函数。此函数也可以返回一个Promise
和一个值。