0

0

如何使用Vue实现通用SSR和SEO优化?

WBOY

WBOY

发布时间:2023-06-27 11:00:56

|

3895人浏览过

|

来源于php中文网

原创

随着前端技术的发展和应用越来越广泛,用户对于web页面的交互和性能有着越来越高的要求。在这样的背景下,vue作为一种受欢迎的前端框架,早已成为众多开发者眼中的热门选择。同时,随着搜索引擎优化(seo)越来越受到企业和网站拥有者的重视,如何使用vue实现通用ssr和seo优化已成为一个重要议题。本文将介绍如何使用vue实现通用ssr和seo优化。

一、什么是通用SSR?

首先,了解一下通用SSR是什么。SSR,即服务器端渲染(Server-side rendering),它是一种将服务端直接生成HTML文件并返回给客户端的技术。简单来说,SSR就是通过服务端去渲染网页,然后将渲染好的结果返回给浏览器端,这样可以提高页面加载速度和搜索引擎的可访问性。

而通用SSR是指使用同一套代码既能运行在服务器端,生成HTML文件返回客户端,又能在浏览器端运行,实现SPA(Single-page Application)所具有的交互性、速度和美观性。通用SSR在实现上相对比较复杂,但可以解决传统SSR的一些局限性,兼顾用户体验和开发调试。

二、如何使用Vue实现通用SSR?

立即学习前端免费学习笔记(深入)”;

Vue官网提供了一个基于Webpack的SSR模板工程,可以快速上手使用。下面我们来一步步介绍如何使用Vue实现通用SSR。

1、创建项目

首先,我们需要安装Vue CLI,并使用命令行创建一个新项目:

vue create my-project

2、安装和配置SSR插件

在项目根目录下,我们需要安装两个插件,分别是vue-server-rendererwebpack-node-externals,可以使用以下命令进行安装:

npm install vue-server-renderer webpack-node-externals --save

安装好后,在项目的package.json文件中可以看到这两个插件的依赖。

然后我们需要在项目中创建一个新的文件夹src/entry-server.jssrc/entry-client.js,分别用来作为服务端和客户端的入口脚本。随后需要在vue.config.js配置文件中添加如下代码:

const VueSSRServerPlugin = require('vue-server-renderer/server-plugin')
const VueSSRClientPlugin = require('vue-server-renderer/client-plugin')
const nodeExternals = require('webpack-node-externals')

const TARGET_NODE = process.env.WEBPACK_TARGET === 'node'
const target = TARGET_NODE ? 'server' : 'client'

module.exports = {
  css: {
    extract: false
  },
  outputDir: './dist/' + target,
  configureWebpack: () => ({
    entry: `./src/entry-${target}.js`,
    devtool: 'source-map',
    target: TARGET_NODE ? 'node' : 'web',
    node: TARGET_NODE ? undefined : false,
    output: {
      libraryTarget: TARGET_NODE ? 'commonjs2' : undefined
    },
    optimization: {
      splitChunks: TARGET_NODE ? false : undefined
    },
    externals: TARGET_NODE ? nodeExternals({
      allowlist: [/.css$/]
    }) : undefined,
    plugins: [
      TARGET_NODE ? new VueSSRServerPlugin() : new VueSSRClientPlugin()
    ]
  }),
  chainWebpack: config => {
    config.module
      .rule('vue')
      .use('vue-loader')
      .tap(options => {
        options.optimizeSSR = false
        return options
      })
  }
}

然后,在服务器端入口文件entry-server.js中添加如下代码:

import { createApp } from './app'

export default context => {
  return new Promise((resolve, reject) => {
    const { app, router, store } = createApp()

    router.push(context.url)

    router.onReady(() => {
      const matchedComponents = router.getMatchedComponents()

      if (!matchedComponents.length) {
        return reject({ code: 404 })
      }

      Promise.all(matchedComponents.map(Component => {
        if (Component.asyncData) {
          return Component.asyncData({
            store,
            route: router.currentRoute
          })
        }
      })).then(() => {
        context.state = store.state

        resolve(app)
      }).catch(reject)
    }, reject)
  })
}

在客户端入口文件entry-client.js中添加如下代码:

import { createApp } from './app'

const { app, router, store } = createApp()

router.onReady(() => {
  if (window.__INITIAL_STATE__) {
    store.replaceState(window.__INITIAL_STATE__)
  }

  app.$mount('#app')
})

此外,我们还需要创建一个src/app.js文件,包含Vue实例创建、路由、状态管理等代码,具体如下:

import Vue from 'vue'
import App from './App.vue'
import { createRouter } from './router'
import { createStore } from './store'

Vue.config.productionTip = false

export function createApp() {
  const router = createRouter()
  const store = createStore()

  const app = new Vue({
    router,
    store,
    render: h => h(App)
  })

  return { app, router, store }
}

最后,在public/index.html中添加<div id="app"></div>标签作为Vue实例挂载的目标。

3、启动开发环境

在完成以上配置后,我们可以通过以下命令启动开发环境:

npm run serve

4、构建并启动生产环境

永利在线企业网站管理系统(CMS)1.0 Build 20100612
永利在线企业网站管理系统(CMS)1.0 Build 20100612

修正说明:1,实现真正的软件开源。2,安装界面的美化3,真正实现栏目的递归无限极分类。4,后台添加幻灯片图片的管理,包括添加,修改,删除等。5,修正添加新闻的报错信息6,修正网站参数的logo上传问题7,修正产品图片的栏目无限极分类8,修正投票系统的只能单选问题9,添加生成静态页功能10,添加缓存功能特点和优势1. 基于B/S架构,通过本地电脑、局域网、互联网皆可使用,使得企业的管理与业务不受地域

下载

在开发完成后,我们需要对项目进行构建,并启动生产环境。构建命令:

npm run build

启动生产环境命令:

npm run start

启动生产环境后,可以在浏览器中输入http://localhost:端口号/进行访问。此时,我们就成功地使用Vue实现了通用SSR。

三、如何进行SEO优化?

在使用Vue实现通用SSR后,要想实现SEO优化,需要注意以下几点。

1、为页面添加Meta标签

Meta标签对于SEO优化是非常重要的。在当前网页即将被搜索引擎抓取时,搜索引擎会读取Meta标签中的信息,并根据这些信息来判断关键词、网页描述、页面语言等内容。在Vue中,我们可以通过在服务端渲染时添加Meta标签来进行优化。

以添加网页标题为例,我们可以在entry-server.js中添加如下代码:

context.title = '页面标题'

而在网页模板中,可以使用Vue的模板语法来动态设置Meta标签,例如:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>{{ title }}</title>
  <meta name="keywords" content="{{ keywords }}">
  <meta name="description" content="{{ description }}">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
</head>
<body>
  <div id="app">{{ APP }}</div>
  <script src="{{ shasum }}/js/vendor.js"></script>
  <script src="{{ shasum }}/js/app.js"></script>
</body>
</html>

2、使用预渲染,生成静态HTML文件

预渲染是指在开发阶段,将需要进行SEO优化的页面提前生成静态HTML文件,并在生产环境中使用这些静态HTML文件,而不是每次请求都需要从服务器端重新生成。

我们可以使用插件例如prerender-spa-plugin来进行预渲染。在Vue中,我们可以通过在vue.config.js中添加如下代码来配置prerender-spa-plugin:

const PrerenderSPAPlugin = require('prerender-spa-plugin')
const Renderer = PrerenderSPAPlugin.PuppeteerRenderer

module.exports = {
  // ...其他配置
  configureWebpack: config => {
    if (process.env.NODE_ENV !== 'production') return

    return {
      plugins: [
        new PrerenderSPAPlugin({
          staticDir: path.join(__dirname, 'dist'),
          routes: ['/route1', '/route2', '/route3'],
          renderer: new Renderer({
            renderAfterDocumentEvent: 'render-event'
          })
        })
      ]
    }
  }
}

其中,staticDir属性为静态文件存放路径,routes属性是需要生成静态文件的路由,renderAfterDocumentEvent属性是页面内容渲染完成后,触发的事件名称。

3、使用Schema.org标记

Schema.org是一个以描述数据为主要目标的、由搜索引擎联盟所维护的标准。通过使用Schema.org标记,我们可以向搜索引擎提供更加详细的页面描述和结构化数据,有利于提升网站在搜索引擎排名中的地位。

在Vue中,可以使用vue-meta-info插件来动态设置Schema.org标记,例如:

export default {
  metaInfo() {
    return {
      meta: [
        { name: 'author', content: 'author_name' },
        { name: 'keywords', content: 'keywords1,keywords2' }
      ],
      link: [
        { rel: 'author', href: 'author_link' }
      ],
      script: [
        {
          type: 'application/ld+json',
          json: {
            '@context': 'https://schema.org',
            '@type': 'Person',
            'name': 'John Doe',
          },
        },
      ],
    }
  }
}

总结

在本文中,我们介绍了如何使用Vue实现通用SSR,以及如何进行SEO优化。通过使用通用SSR可以提高网站的加载速度和搜索引擎的可访问性,而通过SEO优化可以进一步提高网站在搜索引擎中的排名。为了更好地优化网站,我们需要不断地学习和实践,并不断调整自己的优化策略。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

48

2026.02.28

Golang 工程化架构设计:可维护与可演进系统构建
Golang 工程化架构设计:可维护与可演进系统构建

Go语言工程化架构设计专注于构建高可维护性、可演进的企业级系统。本专题深入探讨Go项目的目录结构设计、模块划分、依赖管理等核心架构原则,涵盖微服务架构、领域驱动设计(DDD)在Go中的实践应用。通过实战案例解析接口抽象、错误处理、配置管理、日志监控等关键工程化技术,帮助开发者掌握构建稳定、可扩展Go应用的最佳实践方法。

44

2026.02.28

Golang 性能分析与运行时机制:构建高性能程序
Golang 性能分析与运行时机制:构建高性能程序

Go语言以其高效的并发模型和优异的性能表现广泛应用于高并发、高性能场景。其运行时机制包括 Goroutine 调度、内存管理、垃圾回收等方面,深入理解这些机制有助于编写更高效稳定的程序。本专题将系统讲解 Golang 的性能分析工具使用、常见性能瓶颈定位及优化策略,并结合实际案例剖析 Go 程序的运行时行为,帮助开发者掌握构建高性能应用的关键技能。

37

2026.02.28

Golang 并发编程模型与工程实践:从语言特性到系统性能
Golang 并发编程模型与工程实践:从语言特性到系统性能

本专题系统讲解 Golang 并发编程模型,从语言级特性出发,深入理解 goroutine、channel 与调度机制。结合工程实践,分析并发设计模式、性能瓶颈与资源控制策略,帮助将并发能力有效转化为稳定、可扩展的系统性能优势。

22

2026.02.27

Golang 高级特性与最佳实践:提升代码艺术
Golang 高级特性与最佳实践:提升代码艺术

本专题深入剖析 Golang 的高级特性与工程级最佳实践,涵盖并发模型、内存管理、接口设计与错误处理策略。通过真实场景与代码对比,引导从“可运行”走向“高质量”,帮助构建高性能、可扩展、易维护的优雅 Go 代码体系。

19

2026.02.27

Golang 测试与调试专题:确保代码可靠性
Golang 测试与调试专题:确保代码可靠性

本专题聚焦 Golang 的测试与调试体系,系统讲解单元测试、表驱动测试、基准测试与覆盖率分析方法,并深入剖析调试工具与常见问题定位思路。通过实践示例,引导建立可验证、可回归的工程习惯,从而持续提升代码可靠性与可维护性。

3

2026.02.27

漫蛙app官网链接入口
漫蛙app官网链接入口

漫蛙App官网提供多条稳定入口,包括 https://manwa.me、https

268

2026.02.27

deepseek在线提问
deepseek在线提问

本合集汇总了DeepSeek在线提问技巧与免登录使用入口,助你快速上手AI对话、写作、分析等功能。阅读专题下面的文章了解更多详细内容。

51

2026.02.27

AO3官网直接进入
AO3官网直接进入

AO3官网最新入口合集,汇总2026年可用官方及镜像链接,助你快速稳定访问Archive of Our Own平台。阅读专题下面的文章了解更多详细内容。

430

2026.02.27

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Vue 教程
Vue 教程

共42课时 | 9.1万人学习

Vue3.x 工具篇--十天技能课堂
Vue3.x 工具篇--十天技能课堂

共26课时 | 1.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号