网站LOGO
白雾茫茫丶
页面加载中
12月4日
网站LOGO 白雾茫茫丶
记录学习、生活和有趣的事
菜单
  • 白雾茫茫丶
    记录学习、生活和有趣的事
    用户的头像
    首次访问
    上次留言
    累计留言
    我的等级
    我的角色
    打赏二维码
    打赏博主
    Nuxt3 实战 (六):Footer 底部布局
    点击复制本页信息
    微信扫一扫
    文章二维码
    文章图片 文章标题
    创建时间
  • 一 言
    确认删除此评论么? 确认
  • 本弹窗介绍内容来自,本网站不对其中内容负责。
    • 复制图片
    • 复制图片地址
    • 百度识图
    按住ctrl可打开默认菜单

    Nuxt3 实战 (六):Footer 底部布局

    谢明伟 · 原创 ·
    前端开发Nuxt3 实战 · VueNuxt
    共 4196 字 · 约 1 分钟 · 836
    本文最后更新于2024年04月29日,已经过了218天没有更新,若内容或图片失效,请留言反馈

    前言

    今天开发项目的 Footer 布局,这里我们参考 Nuxt-UI 官网的布局。

    需求拆分

    1. 准备好域名备案号和 icp 图标
    2. 底部社交按钮链接或其他链接
    3. AppFooter 组件开发

    Footer 布局

    1. 新建 components/AppFooter.vue 文件:

      js 代码:
      <template>
       <footer class="fixed bottom-0 w-full">
      <UDivider :avatar="{ src: '/logo.svg' }" />
      <div class="flex justify-between items-center px-4 md:px-8 lg:px-32 py-3 max-sm:flex-col -mt-2.5">
       <!-- icp 备案 -->
       <ULink
         to="https://beian.miit.gov.cn/#/Integrated/index"
         target="_blank"
         active-class="text-primary"
         inactive-class="text-sm text-gray-400 hover:text-gray-600 dark:hover:text-gray-300"
       >
         <div class="flex items-center gap-2">
           <NuxtImg
             src="/icp.png"
             alt="粤ICP备2023007649号-3"
             class="w-4"
           />
           粤ICP备2023007649号-3
         </div>
       </ULink>
       <!-- 社交图标 -->
       <div class="max-sm:order-first">
         <!-- github -->
         <SocialButton
           icon="i-ri-github-line"
           url="https://github.com/baiwumm"
           tip="Github"
         />
         <!-- 微信 -->
         <SocialButton
           icon="i-ri-wechat-line"
           url="https://wechat.baiwumm.com/"
           tip="微信"
         />
         <!-- 电子邮箱 -->
         <SocialButton
           icon="i-ri-mail-line"
           url="mailto:baiwumm@foxmail.com"
           tip="Email"
         />
         <!-- 博客 -->
         <SocialButton
           icon="i-ri-quill-pen-line"
           url="https://baiwumm.com"
           tip="博客"
         />
       </div>
      </div>
       </footer>
      </template>
    2. layouts/default.vue 文件配置组件:

      html 代码:
      <template>
       <div>
      <!-- header -->
      <AppHeader />
      <!-- main -->
      <slot />
      <!-- footer -->
      <AppFooter />
       </div>
      </template>
    3. 这里我们顺便给 AppColorMode 组件加个切换过渡动画,让网站丰富一点:

      js 代码:
       <script setup lang="ts">
       const colorMode = useColorMode()
      
       // 切换模式
       const setColorMode = () => {
      colorMode.value = colorMode.value === 'dark' ? 'light' : 'dark'
       }
      
       // 判断是否支持 startViewTransition API
       const enableTransitions = () =>
      'startViewTransition' in document &&
      window.matchMedia('(prefers-reduced-motion: no-preference)').matches
      
       // 切换动画
       async function toggleDark({ clientX: x, clientY: y }: MouseEvent) {
      const isDark = colorMode.value === 'dark'
      
      if (!enableTransitions()) {
       setColorMode()
       return
      }
      
      const clipPath = [
       `circle(0px at $px ${y}px)`,
       `circle(${Math.hypot(
         Math.max(x, innerWidth - x),
         Math.max(y, innerHeight - y)
       )}px at $px ${y}px)`
      ]
      
      await document.startViewTransition(async () => {
       setColorMode()
       await nextTick()
      }).ready
      
      document.documentElement.animate(
       { clipPath: !isDark ? clipPath.reverse() : clipPath },
       {
         duration: 300,
         easing: 'ease-in',
         pseudoElement: `::view-transition-${!isDark ? 'old' : 'new'}(root)`
       }
      )
       }
       </script>
      
       <template>
      <UTooltip :text="`切换${$colorMode.value === 'dark' ? '白天' : '黑夜'}模式`">
       <UButton
         :icon="$colorMode.value === 'dark' ? 'i-heroicons-moon-solid' : ' i-heroicons-sun-solid'"
         size="sm"
         variant="ghost"
         class="text-gray-700 dark:text-gray-200 hover:text-gray-900 dark:hover:text-white hover:bg-gray-50 dark:hover:bg-gray-800"
         @click="toggleDark"
       />
      </UTooltip>
       </template>
      
       <style>
       ::view-transition-old(root),
       ::view-transition-new(root) {
      animation: none;
      mix-blend-mode: normal;
       }
      
       ::view-transition-old(root),
       .dark::view-transition-new(root) {
      z-index: 1;
       }
      
       ::view-transition-new(root),
       .dark::view-transition-old(root) {
      z-index: 9999;
       }
       </style>

    最终效果

    总结

    这个篇章内容比较简单,下一篇开发主体内容。

    好了,今天就到这吧!

    Github 仓库dream-site

    线上预览dream-site.cn

    声明:本文由 谢明伟(博主)原创,依据 CC-BY-NC-SA 4.0 许可协议 授权,转载请注明出处。

    还没有人喜爱这篇文章呢

    我要发表评论 我要发表评论
    博客logo 白雾茫茫丶 记录学习、生活和有趣的事 51统计 百度统计
    MOEICP 萌ICP备20236860号 ICP 粤ICP备2023007649号 ICP 粤公网安备44030402006402号

    💻️ 谢明伟 昨天 17:36 在线

    🕛

    本站已运行 2 年 337 天 19 小时 59 分

    🌳

    自豪地使用 Typecho 建站,并搭配 MyLife 主题
    白雾茫茫丶. © 2022 ~ 2024.
    网站logo

    白雾茫茫丶 记录学习、生活和有趣的事