出品
开源中国
文
局长
uni-app团队近期在完成Vue3.0的全平台升级后,基于Vue3.0+uniCloud,发布了开箱即用的SSR支持,官方称其为uniCloud版的SSR。
据介绍,SSR(服务端渲染)可以给SPA站点带来两大核心优势:
更好的SEO
更快的首屏渲染
下面是一个uniCloud版的SSR示例:news.dcloud.io是基于uni-appuniCloud开发的新闻系统。通过审查元素会发现,新闻列表数据包含在服务端下发的源码中,而不是客户端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来实现状态同步;步骤二:编译发行
通过HBuilderX的发行菜单-网站PC-Web或手机H5、勾选ssr、勾选将编译后的资源部署在uniCloud前端网页托管
这个过程,对开发者来说很简单,只需要点击按钮即可,实际上HBuilderX在背后做了大量工作,包括:
编译uni-app项目,分别生成ServerBundle和ClientBundle
将ClientBundle上传到uniCloud前端网页托管中
将ServerBundle作为uni-ssr云函数资源,编译并上传到uniCloud服务空间
步骤三:配置uni-ssr云函数的URL化路径
给uni-ssr云函数绑定自定义域名,然后在浏览器中访问该域名,就可以获得服务端渲染的页面了。
至此,uniCloud版SSR开发部署工作结束。
最后看看传统SSR与uniCloud版SSR的优缺点对比: