2

所以我尝试在 css 上进行页面转换,但leave转换不起作用,所以我尝试使用JS Hooks,但留下动画仍然不起作用。我试着评论每一步,我发现leave甚至没有被调用。

脚本:

methods: {
    beforeEnter: function (el) {
      console.log("Before Enter")
      // ...
    },
    enter: function (el, done) {
      console.log("Entered")
      // ...
    },
    leave: function (el, done) {
      console.log("Leave")
      // ...
    }
  }

模板:

<div id="app">
  <nav-bar />
  <transition
    mode="out-in"
    @before-enter="beforeEnter"
    @enter="enter"
    @leave="leave"
  >
    <nuxt />
  </transition>
</div>

网站行为截图

我已经阅读了转换的文档,我什至复制了他们的代码并按原样粘贴,但似乎仍然没有区别。我用过yarn create nuxt-app,所以你会认为我正在进行最稳定的更新

nuxt: 2.15.8

node: 14.18.1

ubuntu: 18.04.6 LTS
4

1 回答 1

2

您链接的文档与 Vue3 相关,与 Nuxt2(使用 Vue2)相比,那里的 API 有点不同。
这是你应该看看的

这是迄今为止最容易管理的过渡

<transition name="slide-fade">
  <p v-if="show">hello</p>
</transition>
.slide-fade-enter-active {
  transition: all .3s ease;
}
.slide-fade-leave-active {
  transition: all .8s cubic-bezier(1.0, 0.5, 0.8, 1.0);
}
.slide-fade-enter, .slide-fade-leave-to
/* .slide-fade-leave-active below version 2.1.8 */ {
  transform: translateX(10px);
  opacity: 0;
}
于 2021-12-22T16:47:42.447 回答