VNode Lifecycle Events breaking
Overview
In Vue 2, it was possible to use events to listen for key stages in a component's lifecycle. These events had names that started with the prefix hook:
, followed by the name of the corresponding lifecycle hook.
In Vue 3, this prefix has been changed to vnode-
. In addition, these events are now available for HTML elements as well as components.
2.x Syntax
In Vue 2, the event name is the same as the equivalent lifecycle hook, prefixed with hook:
:
<template> <child-component @hook:updated="onUpdated"> </template>
3.x Syntax
In Vue 3, the event name is prefixed with vnode-
:
<template> <child-component @vnode-updated="onUpdated"> </template>
Or just vnode
if you're using camel case:
<template> <child-component @vnodeUpdated="onUpdated"> </template>
Migration Strategy
In most cases it should just require changing the prefix. The lifecycle hooks beforeDestroy
and destroyed
have been renamed to beforeUnmount
and unmounted
respectively, so the corresponding event names will also need to be updated.
Migration build flags: INSTANCE_EVENT_HOOKS
See Also
© 2013–present Yuxi Evan You
Licensed under the MIT License.
https://v3.vuejs.org/guide/migration/vnode-lifecycle-events.html