使用事件是解耦应用程序、允许代码不同部分之间进行更灵活和模块化通信的绝佳方式。事件可以有多个不相互依赖的监听器。例如,您可能希望在每次订单发货时向用户发送电子邮件。与其将订单处理代码与电子邮件代码耦合,不如发出一个事件,监听器可以接收该事件并用于发送电子邮件。
Nuxt 事件系统由unjs/hookable提供支持,这与为 Nuxt hooks 系统提供支持的库是同一个。
您可以使用 hook 方法创建自己的自定义事件
const nuxtApp = useNuxtApp()
nuxtApp.hook('app:user:registered', (payload) => {
console.log('A new user has registered!', payload)
})
要发出事件并通知所有监听器,请使用 callHook
const nuxtApp = useNuxtApp()
await nuxtApp.callHook('app:user:registered', {
id: 1,
name: 'John Doe',
})
您还可以使用 payload 对象在发射器和监听器之间实现双向通信。由于 payload 是按引用传递的,监听器可以修改它以将数据发送回发射器。
const nuxtApp = useNuxtApp()
nuxtApp.hook('app:user:registered', (payload) => {
payload.message = 'Welcome to our app!'
})
const payload = {
id: 1,
name: 'John Doe',
}
await nuxtApp.callHook('app:user:registered', {
id: 1,
name: 'John Doe',
})
// payload.message will be 'Welcome to our app!'