Transition as Root
breaking

Overview

Using a <transition> as a component's root will no longer trigger transitions when the component is toggled from the outside.

2.x Behavior

In Vue 2, it was possible to trigger a transition from outside a component by using a <transition> as the component's root:

<!-- modal component -->
<template>
  <transition>
    <div class="modal"><slot/></div>
  </transition>
</template>
<!-- usage -->
<modal v-if="showModal">hello</modal>

Toggling the value of showModal would trigger a transition inside the modal component.

This worked by accident, not by design. A <transition> is supposed to be triggered by changes to its children, not by toggling the <transition> itself.

This quirk has now been removed.

Migration Strategy

A similar effect can be achieved by passing a prop to the component instead:

<template>
  <transition>
    <div v-if="show" class="modal"><slot/></div>
  </transition>
</template>
<script>
export default {
  props: ['show']
}
</script>
<!-- usage -->
<modal :show="showModal">hello</modal>

See also

© 2013–present Yuxi Evan You
Licensed under the MIT License.
https://v3.vuejs.org/guide/migration/transition-as-root.html