前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Nuxt3 实战 (十一):添加路由 Transition 过渡效果和 Loading 动画

Nuxt3 实战 (十一):添加路由 Transition 过渡效果和 Loading 动画

原创
作者头像
白雾茫茫丶
发布2024-06-20 16:21:59
1430
发布2024-06-20 16:21:59
举报
文章被收录于专栏:Nuxt3 实战系列Nuxt3 实战系列

页面过渡效果

Nuxt3 利用 Vue<Transition>组件 在页面和布局之间应用过渡效果。

1、 nuxt.config.ts 文件配置:

代码语言:javascript
复制
 export default defineNuxtConfig({
   app: {
     pageTransition: { name: 'page', mode: 'out-in' }
   },
 })

2、 在页面之间添加过渡效果,在 app.vue 文件中添加以下 CSS

代码语言:html
复制
 <template>
    <NuxtPage />
  </template>

  <style>
  .page-enter-active,
  .page-leave-active {
    transition: all 0.4s;
  }
  .page-enter-from,
  .page-leave-to {
    opacity: 0;
    filter: blur(1rem);
  }
  </style>

3、 要为页面设置不同的过渡效果,请在页面的 definePageMeta 中设置 pageTransition 键:

代码语言:html
复制
 <script setup lang="ts">
 definePageMeta({
   pageTransition: {
     name: 'rotate'
   }
 })
 </script>

如果你同时更改布局和页面,这里设置的页面过渡效果将不会运行。相反,你应该设置布局过渡效果

布局过渡效果

1、 nuxt.config.ts 文件配置:

代码语言:js
复制
 export default defineNuxtConfig({
   app: {
     layoutTransition: { name: 'layout', mode: 'out-in' }
   },
 })

2、 在 app.vue 文件中添加代码:

代码语言:html
复制
 <template>
  <NuxtLayout>
    <NuxtPage />
  </NuxtLayout>
 </template>

 <style>
 .layout-enter-active,
 .layout-leave-active {
   transition: all 0.4s;
 }
 .layout-enter-from,
 .layout-leave-to {
   filter: grayscale(1);
 }
 </style>

首屏加载动画

Nuxt3 并没有直接提供 API,但我们利用 生命周期钩子 来完成我们期望的效果。

1、 新建 components/FullLoading/index.vue 文件:

代码语言:html
复制
   <template>
    <div
      class="fixed flex w-screen h-screen justify-center items-center flex-col z-[99] overflow-hidden bg-white dark:bg-slate-900"
    >
      <div
        class="relative w-12 h-12 rotate-[165deg] before:content-[''] after:content-[''] before:absolute after:absolute before:top-2/4 after:top-2/4 before:left-2/4 after:left-2/4 before:block after:block before:w-[.5em] after:w-[.5em] before:h-[.5em] after:h-[.5em] before:rounded after:rounded before:-translate-x-1/2 after:-translate-x-1/2 before:-translate-y-2/4 after:-translate-y-2/4 before:animate-[loaderBefore_2s_infinite] after:animate-[loaderAfter_2s_infinite]"
      />
    </div>
  </template>
  <style>
  @keyframes loaderBefore {
    0% {
      width: 0.5em;
      box-shadow:
        1em -0.5em rgba(225, 20, 98, 0.75),
        -1em 0.5em rgba(111, 202, 220, 0.75);
    }

    35% {
      width: 2.5em;
      box-shadow:
        0 -0.5em rgba(225, 20, 98, 0.75),
        0 0.5em rgba(111, 202, 220, 0.75);
    }

    70% {
      width: 0.5em;
      box-shadow:
        -1em -0.5em rgba(225, 20, 98, 0.75),
        1em 0.5em rgba(111, 202, 220, 0.75);
    }

    100% {
      box-shadow:
        1em -0.5em rgba(225, 20, 98, 0.75),
        -1em 0.5em rgba(111, 202, 220, 0.75);
    }
  }

  @keyframes loaderAfter {
    0% {
      height: 0.5em;
      box-shadow:
        0.5em 1em rgba(61, 184, 143, 0.75),
        -0.5em -1em rgba(233, 169, 32, 0.75);
    }

    35% {
      height: 2.5em;
      box-shadow:
        0.5em 0 rgba(61, 184, 143, 0.75),
        -0.5em 0 rgba(233, 169, 32, 0.75);
    }

    70% {
      height: 0.5em;
      box-shadow:
        0.5em -1em rgba(61, 184, 143, 0.75),
        -0.5em 1em rgba(233, 169, 32, 0.75);
    }

    100% {
      box-shadow:
        0.5em 1em rgba(61, 184, 143, 0.75),
        -0.5em -1em rgba(233, 169, 32, 0.75);
    }
  }
  </style>

2、app.vue 添加代码:

代码语言:html
复制
   <script setup lang="ts">
  const nuxtApp = useNuxtApp()

  // 是否首次加载
  const isFullLoading = ref(true)

  nuxtApp.hook('page:start', () => {
    isFullLoading.value = true
  })

  nuxtApp.hook('page:finish', () => {
    isFullLoading.value = false
  })
  </script>

  <template>
    <div>
      <!-- 首页加载全屏动画 -->
      <FullLoading v-if="isFullLoading" />
      <NuxtLayout>
        <NuxtPage />
      </NuxtLayout>
    </div>
  </template>

页面进度条

我们还可以添加一个页面进度条,Nuxt3 提供了 <NuxtLoadingIndicator> 组件,我们直接在 app.vue 中添加:

代码语言:html
复制
<template>
  <NuxtLayout>
    <!-- 在页面导航之间显示一个进度条 -->
    <NuxtLoadingIndicator />
    <NuxtPage />
  </NuxtLayout>
</template>

效果预览

总结

通过本篇文章我们学习了如何在 Nuxt3 中添加路由切换过渡效果和首屏加载动画,没什么干货,按照官方文档操作就完事了。

Github 仓库dream-site

线上预览dream-site.cn

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 页面过渡效果
  • 布局过渡效果
  • 首屏加载动画
  • 页面进度条
  • 效果预览
  • 总结
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档