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

    Nuxt3 实战 (十二):SEO 搜索引擎优化指南

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

    添加 favicon 图标和 TDK(标题、描述、关键词)

    1. nuxt.config.ts 添加配置:

      ts 代码:
      export default defineNuxtConfig({
        app: {
      title:'Dream Site',
      meta: [
        { name: 'keywords', content: 'Nuxt.js,导航,网站' },
        { name: 'description', content: '致力于打造程序员的梦中情站' }
      ],
      link: [{ rel: 'icon', type: 'image/x-icon', href: 'favicon.ico' }],
      style: [],
      script: [],
      noscript: []
        }
      })
    2. 使用 useHead

      html 代码:
      <script setup lang="ts">
        useHead({
      title:'Dream Site',
      link: [{ rel: 'icon', type: 'image/x-icon', href: 'favicon.ico' }],
      meta: [
       { name: 'keywords', content: 'Nuxt.js,导航,网站' },
       { name: 'description', content: '致力于打造程序员的梦中情站' }
      ]
        })
      </script>
    3. 使用 useSeoMeta 组合函数

      html 代码:
      <script setup lang="ts">
       useSeoMeta({
       title: 'Dream Site',
       ogTitle: 'Dream Site',
       description: '致力于打造程序员的梦中情站',
       ogDescription: '致力于打造程序员的梦中情站',
       ogImage: 'https://example.com/image.png',
       twitterCard: 'summary_large_image',
       })
      </script>
    4. /pages/ 目录中可以使用 definePageMeta 来根据当前路由设置元数据

      html 代码:
      <script setup lang="ts">
       definePageMeta({
      title: 'Dream Site'
       })
      </script>
    5. 动态标题

      html 代码:
      <script setup lang="ts">
      useHead({
       // 作为字符串,
       // 其中`%s`会被标题替换
       titleTemplate: '%s - Dream Site',
       // ... 或者作为一个函数
       titleTemplate: (productCategory) => {
      return productCategory
       ? `${productCategory} - Dream Site`
       : 'Dream Site'
       }
      })
      </script>

    官方文档:SEO和Meta

    安装 @nuxtjs/seo 模块

    我们需要安装 @nuxtjs/seo 插件,@nuxtjs/seo 是一个模块集合,它覆盖了搜索引擎中常用的模块:

    具体使用方式:

    1. @nuxtjs/seo 插件:

      bash 代码:
      npx nuxi@latest module add seo
    2. nuxt.config.ts 中根据实际情况添加配置:

      ts 代码:
       export default defineNuxtConfig({
      // SEO 配置
      site: {
       url: 'https://dream-site.cn',
       name: 'Dream Site',
       description: '致力于打造程序员的梦中情站',
       defaultLocale: 'zh-cn',
       exclude: ['/admin/_components/**'], // 过滤不需要的 url
       cacheMaxAgeSeconds: 24 * 3600, // 缓存时间一天
       autoLastmod: true, // 自动检测每个 URL 的 lastmod 日期
      },
      routeRules: {
       // Don't add any /secret/** URLs to the sitemap.xml
       '/admin/_components/**': { robots: false },
      }
       })

    现在你就能打开 sitemap.xmlrobots.txt 了,其他更加详细的配置可以参考官方文档:nuxt-seo

    Robots

    1. 禁用网站索引

      ts 代码:
      export default defineNuxtConfig({
        site: { indexable: false }
      })
    2. 禁用页面索引

      html 代码:
      <script lang="ts" setup>
      defineRouteRules({
        robots: false,
      })
      </script>
    3. 如果需要更精细的编程控制,可以使用 nuxt.config.ts 配置该模块

      ts 代码:
      export default defineNuxtConfig({
        robots: {
      disallow: ['/secret', '/admin'],
        }
      })

    更加详细的配置可以参考官方文档:Robots

    Sitemap

    1. 禁用 URL 模式的索引

      ts 代码:
      export default defineNuxtConfig({
       routeRules: {
      // Don't add any /secret/** URLs to the sitemap.xml
      '/secret/**': { robots: false },
       }
      })
    2. 对于所有其他情况,您可以使用 includeexclude 模块选项来过滤 url

      ts 代码:
      export default defineNuxtConfig({
       sitemap: {
      // exclude all URLs that start with /secret
      exclude: ['/secret/**'],
      // include all URLs that start with /public
      include: ['/public/**'],
       }
      })
    3. 设置 Lastmodchangefreqpriority

      html 代码:
      <script setup>
      useSeoMeta({
        // will be inferred as the lastmod value in the sitemap
        articleModifiedTime: '2023-01-01'
      })
      
      defineRouteRules({
        sitemap: {
      changefreq: 'daily',
      priority: 0.3
        }
      })
      </script>
    4. 缓存时间

      ts 代码:
      export default defineNuxtConfig({
        sitemap: {
      cacheMaxAgeSeconds: 3600 // 1 hour
        }
      })
    5. 自定义样式

      ts 代码:
      export default defineNuxtConfig({
       sitemap: {
      xslColumns: [
       { label: 'URL', width: '50%' },
       { label: 'Last Modified', select: 'sitemap:lastmod', width: '25%' },
       { label: 'Priority', select: 'sitemap:priority', width: '12.5%' },
       { label: 'Change Frequency', select: 'sitemap:changefreq', width: '12.5%' },
      ],
       },
      })

    更加详细的配置可以参考官方文档:Sitemap

    OG Image

    1. 使用可组合 defineOgImageComponent 来定义主页的 og:image

      html 代码:
      <script lang="ts" setup>
       defineOgImageComponent('NuxtSeo')
      </script>
    2. 在浏览器中访问主页并打开 Nuxt DevTools (Shift + Alt + D)
    3. 自定义模板

      html 代码:
      <script lang="ts" setup>
      defineOgImageComponent('NuxtSeo', {
       title: 'Hello OG Image 👋',
       description: 'Look what at me in dark mode',
       theme: '#ff0000',
       colorMode: 'dark',
      })
      </script>

    更加详细的配置可以参考官方文档:OG Image

    Schema.org

    1. 配置默认值

      html 代码:
      <script lang="ts" setup>
      useSchemaOrg([
       defineWebPage({
      name: 'My Page'
       }),
       defineWebSite({
      name: 'My Site'
       })
      ])
      </script>
    2. 如果你不想使用默认值

      ts 代码:
      export default defineNuxtConfig({
       schemaOrg: {
      default: false
       }
      })
    3. 设置身份类型

      ts 代码:
      export default defineNuxtConfig({
       schemaOrg: {
      identity: {
       type: 'Organization', // or 'Person'
       name: 'My Company',
       url: 'https://example.com',
       logo: 'https://example.com/logo.png'
      }
       }
      })
    4. 自定义节点

      html 代码:
      <script lang="ts" setup>
      useSchemaOrg([
       {
      '@type': 'DefinedTerm',
      'name': 'Nuxt Schema.org',
      'description': 'Nuxt Schema.org is a Nuxt module for adding Schema.org to your Nuxt app.',
      'inDefinedTermSet': {
       '@type': 'DefinedTermSet',
       'name': 'Nuxt Modules',
      },
       }
      ])
      </script>

    更加详细的配置可以参考官方文档:Schema.org

    添加 Google Analytics 统计代码

    1. 安装 nuxt-gtag

      bash 代码:
      npx nuxi@latest module add gtag
    2. nuxt.config.ts 添加配置:

      ts 代码:
      export default defineNuxtConfig({
        modules: ['nuxt-gtag'],
      
        gtag: {
      id: 'G-XXXXXXXXXX'
        }
      })
    3. 或者在环境变量中添加 NUXT_PUBLIC_GTAG_ID

      env 代码:
      NUXT_PUBLIC_GTAG_ID = G-XXXXXXXXXX

    添加 Microsoft Clarity 统计代码

    1. 安装 nuxt-clarity-analytics

      bash 代码:
      pnpm add -D nuxt-clarity-analytics
    2. nuxt.config.ts 添加依赖:

      ts 代码:
      export default defineNuxtConfig({
        modules: [
      'nuxt-clarity-analytics'
        ]
      })
    3. 在环境变量中添加:

      env 代码:
      MICROSOFT_CLARITY_ID = 'clarity ID'

    添加 Umami 统计代码

    1. 安装 nuxt-umami

      bash 代码:
      pnpm add nuxt-umami
    2. nuxt.config.ts 添加配置:

      ts 代码:
      defineNuxtConfig({
        extends: ['github:ijkml/nuxt-umami']
      });
    3. app.config.ts 添加配置:

      ts 代码:
      export default defineAppConfig({
        umami: {
      id: '95653e90-7b8b-4541-b6de-ea5e544d8c2d',
      host: 'https://umami.baiwumm.com',
      useDirective: true,
      version: 2,
      domains: ['dream-site.cn'],
      ignoreLocalhost: true
       }
      });
    4. 跟踪事件

      html 代码:
      <button v-umami="'Event-Name'">
        Event Button
      </button>
      
      <button v-umami="{name: 'Event-Name'}">
        as object
      </button>
      
      <button v-umami="{name: 'Event-Name', position: 'left', ...others}">
        with event details
      </button>

    详细文档:nuxt-umami

    总结

    Nuxt3 集成了很多 SEO Modules,使开发者能够更加高效便捷地做好搜索引擎方面的优化。

    好了,这篇文章就到这了,希望对你有所帮助!

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

    还没有人喜爱这篇文章呢

    现在已有

    4

    条评论
    我要发表评论
    1. · · 陕西-西安
      • 等级:Lv.1
      • 角色:访客
      • 在线:本月
      头像
      沙发

      博主,你怎么不更新nuxt3了,感觉的博文涉猎很广,很规范。求更! OωO

      评论
      1. · · 广东-深圳
        • 角色:博主
        • 在线:本周
        头像

        你好,感谢关注!
        因为那时候使用Nuxt3的时候,感觉那个版本有些许Bug,想等官方完善下再去碰Nuxt.js,目前在折腾Next.js15。

        评论
        1. · · 陕西-西安
          • 等级:Lv.1
          • 角色:访客
          • 在线:本月
          头像

          我是做后端的,23年底用nuxt3写的自己的项目,当时好多组件不适配,就做了博客和时光邮箱就放弃了,希望博主可以接着更新,我看好你!

          评论
          1. · · 广东-深圳
            • 角色:博主
            • 在线:本周
            头像

            等我把Next.js这个系列更新的差不多,过完年就开始研究Nuxt,一起加油!

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

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

    🕛

    本站已运行 3 年 17 天 16 小时 22 分

    🌳

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

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