深入浅出通过vue-cli3构建一个SSR应用程序【实践】
文章插图
作者:lentoo
转发链接:
https://www.jianshu.com/p/bb07d77b91f7
1、前沿1.1、什么是SSR
SSR(服务端渲染)顾名思义就是将页面在服务端渲染完成后在客户端直接展示 。1.2、客户端渲染与服务端渲染的区别传统的SPA模式
即客户端渲染的模式
- Vue.js构建的应用程序,默认情况下是有一个html模板页,然后通过webpack打包生成一堆js、css等等资源文件 。然后塞到index.html中
- 用户输入url访问页面 -> 先得到一个html模板页 -> 然后通过异步请求服务端数据 -> 得到服务端的数据 -> 渲染成局部页面 -> 用户
即服务端渲染模式
- 用户输入url访问页面 -> 服务端接收到请求 -> 将对应请求的数据渲染完一个网页 -> 返回给用户
ssr的好处官网已经给出,最有意思的两个优点如下:
- 更有好的SEO 。由于搜索引擎爬虫抓取工具可以直接查看完全渲染的页面 。
- 更快的内容到达时间(time-to-content)
- Client Bundle,给浏览器用 。和纯Vue前端项目Bundle类似
- Server Bundle,供服务端SSR使用,一个json文件
文章插图
image
2、开始构建基于vue-cli3 的SSR应用程序
了解ssr原理后,来开始step by step搭建一个自己的SSR应用程序
- 安装vue-cli3
npm install @vue/cli -g --registry=https://registry.npm.taobao.org
- 创建一个vue项目
vue create ssr-example
会进入到一个交互bash界面,按自己需要选择文章插图
image
一步一步回车,根据自己需要选择
- 运行项目
npm run serve
文章插图
image
看到这个提示,说明成功了一半了,接下来进行后一半的改造 。
3、进行SSR改造3.1 安装需要的包
- 安装 vue-server-renderer
- 安装 lodash.merge
- 安装 webpack-node-externals
- 安装 cross-env
npm install vue-server-renderer lodash.merge webpack-node-externals cross-env --registry=https://registry.npm.taobao.org --save-dev
3.2 在服务器中集成- 在项目根目录下新建一个server.js
- 安装koa2
npm install koa koa-static --save --registry=https://registry.npm.taobao.org
- 在koa2集成ssr
// server.js// 第 1 步:创建一个 Vue 实例const Vue = require("vue");const Koa = require("koa");const app = new Koa();// 第 2 步:创建一个 rendererconst renderer = require("vue-server-renderer").createRenderer();// 第 3 步:添加一个中间件来处理所有请求app.use(async (ctx, next) => {const vm = new Vue({data: {title: "ssr example",url: ctx.url},template: `<div>访问的 URL 是: {{ url }}</div>`});// 将 Vue 实例渲染为 HTMLrenderer.renderToString(vm, (err, html) => {if(err){ctx.res.status(500).end('Internal Server Error')return}ctx.body = html});});const port = 3000;app.listen(port, function() {console.log(`server started at localhost:${port}`);});
- 运行server.js
node server.js
文章插图
image
看到这个说明一个简单的ssr构建成功了 。
不过到目前为止,我们并没有将客户端的.vue文件通过服务端进行渲染,那么如何将前端的.vue文件与后端node进行结合呢?3.3 改造前端配置,以支持SSR1、修改源码结构
- 在src目录下新建两个文件,一个entry-client.js 仅运行于浏览器 一个entry-server.js 仅运行于服务器
- 修改main.js
- 免费查手机 怎么通过手机查老公的行踪
- 可以通过哪些方式来挣钱 网页游戏工作室怎么赚钱
- 可以通过什么方式赚钱 面包车创业项目有哪些
- 手机推特如何注册,解决手机号码无法通过验证难题
- 王者荣耀是一款5V5公平对战手游,对线双方需要通过打野、清理兵线、击杀来获取经济
- 马化腾大意了,王者荣耀被抢注为酒类商标,腾讯通过诉讼能要回吗?
- iQOO 8 Pro通过性能强悍的骁龙888 Plus三件套组合
- 抖音关联热点有什么用?抖音上热门审核不通过怎么办?
- 如何通过车牌号查询车主信息? 车牌号码查询
- 数学能力通过游戏来培养