从0搭建vue3+ssr项目

一、Vue SSR项目从输入URL到页面渲染的整个过程:

  1. 客户端请求

    用户在浏览器地址栏输入URL并发起请求。

  2. 服务器接收请求

    服务器接收到这个HTTP请求,开始处理。

  3. 服务器端路由解析

    服务器使用类似于客户端的路由解析逻辑来确定应该展示哪个组件。在Vue SSR中,通常使用vue-routermatch功能来实现。

  4. 创建Vue实例

    服务器创建一个新的Vue实例。这通常由一个工厂函数完成,以确保每个请求都是干净、隔离的。

  5. 数据预取和状态填充

    在渲染前,服务器会预取所有必要的数据。这通常通过组件内的特殊生命周期钩子或者路由导航守卫来实现,如asyncDatafetch方法。

  6. 服务器渲染

    使用vue-server-rendererrenderToString方法,将Vue实例及其子组件渲染成HTML字符串。这个过程包括虚拟DOM的创建和对应的HTML标签的生成。

  7. HTML模板处理

    渲染出的HTML会被插入到一个HTML模板中,通常这个模板包含了基本的HTML结构,如<head>标签和未渲染的占位符。

  8. 发送响应

    完整的HTML页面会作为HTTP响应发送给客户端。

  9. 客户端加载和混合

    客户端浏览器接收到HTML文档并开始加载页面。然后它会下载并执行附带的JavaScript文件。Vue客户端版本会接管这个静态HTML并将其转换为响应式的Vue实例,这个过程称为"水合"(hydration)

  10. 客户端路由接管

    完成混合后,vue-router将开始在浏览器端接管路由,之后的页面导航就会在客户端完成,不再请求服务器渲染。

  11. 交互式页面

    用户现在可以与页面交互,所有的Vue功能都是可用的,就像在完全的SPA(单页应用)中一样。

二、搭建项目:

一、搭建node项目,安装依赖

css 复制代码
npm init

npm i express

npm i webpack webpack-cli nodemon -D

创建src文件夹,源代码目录

其下创建server写服务端相关代码

创建config文件夹,用来放置webpack的配置

创建build文件夹,用来放打包后的文件

在package.json中写启动项目命令行

二、webpack配置

在config文件夹中创建serve.config.js,在此处写服务端的打包配置代码

css 复制代码
 npm i @babel/preset-env babel-loader webpack-node-externals -D

使用babel来转义js

webpack-node-externals排除node.js中的内置模块和node_modules中的第三方模块,使它们不被打包进最终的输出文件中,这样可以减小打包文件的体积

package.json中添加打包服务端代码的命令行

三、引入vue

安装vuevue-loader

css 复制代码
npm i vue
npm i vue-loader -D

使用vue-server-rendererrenderToString方法,将Vue实例及其子组件渲染成HTML字符串,当本地访问7777端口时,发送字符串形式的HTML

src下创建client写客户端相关代码,创建并挂载vue实例

和服务端一样,配置下客户端client.config.js的webpack代码

此时发现服务端和客户端很多配置项一样,我们可以优化下,通过webpack-merge抽离下服务端和客户端共同的代码,如下

css 复制代码
npm i webpack-merge -D

新增的vue文件和package.json命令行

打包后运行,点击事件也没有问题,这样一个简易版的vue3+ssr就完成啦。后面我们再集成下路由和状态管理

四、集成路由

安装vue-router

css 复制代码
npm i vue-router

新建两个vue页面和路由文件,客户端用history模式,vue-router为node环境提供了createMemoryHistory模式

此时已是多页面了,将server.get /后加上*,匹配所有7777端口号的页面,根据输入的url来匹配页面。服务端和客户端中都要写路由相关的代码,注意,路由的操作是异步的,要等跳转url后再操作,不要忘了async和await

五、集成状态管理

安装pinia

css 复制代码
npm i pinia

同集成路由一样服务端和客户端中都要写pinia相关的代码,创建pinia实例,安装pinia插件

打包后运行,可以页面跳转,状态共享,这样就完成啦~

相关推荐
熊的猫44 分钟前
JS 中的类型 & 类型判断 & 类型转换
前端·javascript·vue.js·chrome·react.js·前端框架·node.js
瑶琴AI前端1 小时前
uniapp组件实现省市区三级联动选择
java·前端·uni-app
会发光的猪。1 小时前
如何在vscode中安装git详细新手教程
前端·ide·git·vscode
我要洋人死2 小时前
导航栏及下拉菜单的实现
前端·css·css3
科技探秘人3 小时前
Chrome与火狐哪个浏览器的隐私追踪功能更好
前端·chrome
科技探秘人3 小时前
Chrome与傲游浏览器性能与功能的深度对比
前端·chrome
JerryXZR3 小时前
前端开发中ES6的技术细节二
前端·javascript·es6
七星静香3 小时前
laravel chunkById 分块查询 使用时的问题
java·前端·laravel
q2498596933 小时前
前端预览word、excel、ppt
前端·word·excel
小华同学ai3 小时前
wflow-web:开源啦 ,高仿钉钉、飞书、企业微信的审批流程设计器,轻松打造属于你的工作流设计器
前端·钉钉·飞书