不用nuxt如何自己写出来 vue ssr

之前有用nuxt做过几个项目,整体还来说还不错用起来挺方便的,和vue差不多,最明显的地方是asyncData,有任何的ajax要在这个发起,深深的感叹nuxt的强大,配置项之多之便捷。
做过完项目后也有思考服务端渲染到底到底做了什么,node在服务端干了什么,之前查了些资料大概熟悉了下但没整理,今天来整理一次不然过段时间又把这事情忘了,其实了解后就会知道ssr没有想象的那么神秘。

主要内容有两点

第一点:只有用户第一次进来的页面也就是首屏是服务端node组装好的,其余页面还是走的SPA单页面模式,这样处理的结果是 既解决了首屏加速和seo的问题,又结合了SPA单页面的优势。
第二点:流程就是node组装好html返回 本地走vue单页面,重点是这两者怎么续上,第一个页面的数据怎么和后续页面的数据链接上,其实没有链接 html渲染一遍,单页面vue又渲染了一遍,走了两次渲染,数据使用的vuex store.replaceState() 数据链接是用的store的这个api 覆盖的 达到了无缝链接。

基本流程

服务端用node执行 监听端口 查看请求进来
监听 * 也就是该端口的所有请求
获取url 在express 的 res中 url 把路径传递给内部的vue

这里有个注意点 不能用hash模式 因为哈希模式# 后面的任何参数不会发送服务器,node也就无法感知到用户具体访问的是什么

node具体渲染vue 是吧vue的实例解读成 html 字符串 然后返回出去
完成这个过程的插件是 vue-server-render
首先用这个插件 创建一个 renderer实例 createRenderer() 此时可以设置模板 也可以设置缓存什么的
模板要有个注释 相当于占位符 渲染时会替换掉这个占位符位置
renderer.renderToString 这个函数接受 vue实例 和回调函数 回调函数会返回处理好的html 就这么简单 html 然后用express 把这个生成好的字符串返回出去就可以了 返回时可以额外的设置 返回的头什么

接下来的重点是这个vue实例怎么生成

这里有个注意点 无论是 vue 还是 vue-router 还是 vuex 都要用工厂模式 返回一个对象 这单和vue的data是函数 返回一个对象是一个道理每次都返回一个全新的实例 用户与用户之前的访问不会相互影响

正式文件的入口还是以前的main.js 这个js 如刚刚所说 改动下 导出一个函数 createApp 这个函数的执行结果是返回一个vue实例
在这层的基础之上额外的建立两个入口 一个是服务端引用的 一个是客户端引用的
服务端入口 返回一个Promise
接受上面说的 express中获得到的url 引用createApp 并执行 生成新的实例
调用app.router.push传入url 模拟用户进入位置 调用 app.router.getMatchedComponents 这个是返回当前路径下的所有组件
找出所有组件的目的是
1 如果组件数量为0可以返回404
2 找出所有组件的ajax请求 然后立即发起 发起就是Promise.all 执行完毕后一起返回
请求全部发起完毕后 获取 app.$store.state 把所有的store数据拿出来 挂在到context中 不挂也行反正能让 renderer那边拿到就行

这样app实例创建好了 可以传递给 renderToSring 进行转换了
转换成功 即将返回客户端时 把state 赋值到页面的全局变量中
并且在引入固定打包好的 服务端build文件 然后返回出去 这样服务端部分就做好了

客户端入口简单多了
调用createApp 生成实例 把实例 mount 挂在到指定节点 然后判断 页面中是否有全集变量state 如果有则用 app.storoe,replaceState 覆盖即可完成联动

这是最基本的实现原理,实际运用时要优化的地方还有很多例如结合vueRouter meta实现动态的设置title 甚至是关键字 和描述词等,还有动态的热更新。

其实说到这里我有另一种想法。业务代码是业务代码,服务器运行的代码是一个壳子,本地开发是走SPA,线上走SSR。
有两种形式
第一 打包上传时上传两份,一份是一个固定名字的JS文件,这个JS是给首屏SSR固定引用用的,另一份是异步组件被分割的代码用于用户除首屏外的SPA用的。
第二 就打包一份正常被分割的代码,服务端那边麻烦一点嘛,node检索文件夹下面文件的名称匹配app.****.js的文件作为文件入口固定引用。

本片文章也就是处于好奇要自己实现一个SSR该怎么做的目的来写的,其实如果真的需要服务端渲染,还是会去使用nuxt来写,毕竟人家已经做得这么优秀了没理由拒绝。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,099评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,828评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,540评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,848评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,971评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,132评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,193评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,934评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,376评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,687评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,846评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,537评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,175评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,887评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,134评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,674评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,741评论 2 351

推荐阅读更多精彩内容