SSR(服务端渲染)能够给SPA站点带来两大外围劣势:
- 更好的SEO
- 更快的首屏渲染
很多uni-app开发者都在踊跃尝试SSR,但大多没入门就放弃了,起因在于SSR颇高的技术门槛。
vue.js 官网在介绍 SSR 章节时的形容如下:
本指南将会十分深刻,并且假如你曾经相熟 Vue.js 自身,并且具备 Node.js 和 webpack 的相当不错的利用教训。
故很多uni-app开发者在社区中呐喊DCloud官网提供更为简洁、开箱即用的 uni-app SSR计划。
uni-app团队近期在实现 vue 3.0 的全平台降级后,基于vue 3.0 + uniCloud,公布了开箱即用的 SSR 反对,咱们称其为uniCloud版的SSR。
这是一个uniCloud版的SSR示例:news.dcloud.io是基于uni-app & uniCloud 开发的新闻零碎。通过审查元素会发现,新闻列表数据蕴含在服务端下发的源码中,而不是客户端Ajax申请所得。
uniCloud版的SSR实现得较为简单,且和HBuilderX做了深度集成,你能够依照如下步骤疾速上手:
步骤一:调整代码适配服务端运行环境
- 生命周期:uni-app的生命周期钩子函数中,页面onLoad、组件beforeCreate 和 created 会在服务器端渲染 (SSR) 过程中被调用,你须要查看原我的项目代码中获取数据的机会;
- 特定平台API:若间接应用了如 window 或 document,这类仅浏览器反对的全局变量,则会在云端 Node.js 中执行时抛出谬误;
- 数据提取:<uniCloud-db>组件人造反对SSR,无需调整代码,举荐应用<uniCloud-db>查询数据库。如果你未应用<uniCloud-db>组件,则可应用serverPrefetch来实现服务器端数据获取,应用@dcloudio/uni-app提供的ssrRef或Vue.js官网的Vuex来实现状态同步;
更多详细信息及示例代码,参考:https://uniapp.dcloud.net.cn/...
步骤二:编译发行
通过HBuilderX的发行菜单->网站 PC-Web或手机H5、勾选ssr、勾选将编译后的资源部署在uniCloud前端网页托管
这个过程,对开发者来说很简略,只须要点击按钮即可,实际上HBuilderX在背地做了大量工作,包含:
- 编译uni-app我的项目,别离生成Server Bundle和Client Bundle
- 将Client Bundle上传到uniCloud前端网页托管中
- 将Server Bundle作为uni-ssr云函数资源,编译并上传到uniCloud服务空间
步骤三:配置 uni-ssr 云函数的URL化门路
给uni-ssr云函数绑定自定义域名,而后在浏览器中拜访该域名,你就能够取得服务端渲染的页面了。
至此,uniCloud版SSR开发部署工作完结,是不是比原来简略多了?
总结
Vue.js 官网及社区很多文档,介绍SSR时都会提到,SSR是把双刃剑,长处毛病都很显著(2优3缺,缺大于优)。但通过HBuilderX & uniCloud加持的SSR,则完满解决了SSR的局部毛病,将其由缺转优,变成4优1缺,实现优大于缺。具体比照如下:
欢送大家应用uniCloud版SSR!
更多介绍详见:https://uniapp.dcloud.io/coll...