在 Vue 3.0 中,你可以通过 <transition> 元素或 transition 动态组件来定义组件的进入和离开过渡效果。Vue 3.0 中过渡的事件钩子发生了一些变化,与 Vue 2.x 有一些不同。

以下是一个简单的例子,演示了如何使用进入过渡和离开过渡:
<template>
  <div>
    <button @click="toggleShow">切换显示状态</button>
    <transition name="fade" @before-enter="beforeEnter" @enter="enter" @leave="leave">
      <p v-if="show">这是一个过渡效果</p>
    </transition>
  </div>
</template>

<script>
export default {
  data() {
    return {
      show: false
    };
  },
  methods: {
    toggleShow() {
      this.show = !this.show;
    },
    beforeEnter(el) {
      el.style.opacity = 0;
    },
    enter(el, done) {
      el.offsetHeight; // 强制重绘
      el.style.transition = "opacity 0.5s";
      el.style.opacity = 1;
      done();
    },
    leave(el, done) {
      el.style.transition = "opacity 0.5s";
      el.style.opacity = 0;
      done();
    }
  }
};
</script>

<style>
.fade-enter-active, .fade-leave-active {
  transition: opacity 0.5s;
}
.fade-enter, .fade-leave-to {
  opacity: 0;
}
</style>

在这个例子中,<transition> 元素包裹了一个 <p> 元素,通过 @before-enter、@enter、@leave 事件监听不同阶段,定义了进入和离开的过渡效果。

  •  @before-enter 钩子:在进入过渡之前触发,可以在这里进行一些初始化设置。

  •  @enter 钩子:在进入过渡中触发,用于定义进入过渡的动画效果。

  •  @leave 钩子:在离开过渡中触发,用于定义离开过渡的动画效果。


需要注意的是,Vue 3.0 中的 @before-enter 替代了 Vue 2.x 中的 before-enter,其他钩子也有相应的变化。在实际开发中,你可以根据具体的过渡需求来使用相应的事件钩子。


转载请注明出处:http://www.pingtaimeng.com/article/detail/503/Vue 3.0