从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插件

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

相关推荐
ggdpzhk几秒前
VUE:基于MVVN的前端js框架
前端·javascript·vue.js
学不会•2 小时前
css数据不固定情况下,循环加不同背景颜色
前端·javascript·html
活宝小娜4 小时前
vue不刷新浏览器更新页面的方法
前端·javascript·vue.js
程序视点5 小时前
【Vue3新工具】Pinia.js:提升开发效率,更轻量、更高效的状态管理方案!
前端·javascript·vue.js·typescript·vue·ecmascript
coldriversnow5 小时前
在Vue中,vue document.onkeydown 无效
前端·javascript·vue.js
我开心就好o5 小时前
uniapp点左上角返回键, 重复来回跳转的问题 解决方案
前端·javascript·uni-app
开心工作室_kaic5 小时前
ssm161基于web的资源共享平台的共享与开发+jsp(论文+源码)_kaic
java·开发语言·前端
刚刚好ā5 小时前
js作用域超全介绍--全局作用域、局部作用、块级作用域
前端·javascript·vue.js·vue
沉默璇年7 小时前
react中useMemo的使用场景
前端·react.js·前端框架
yqcoder7 小时前
reactflow 中 useNodesState 模块作用
开发语言·前端·javascript