|uni-app 提供开箱即用的 SSR 支持

文章图片
出品|开源中国
文|局长
uni-app 团队近期在完成 Vue 3.0 的全平台升级后 , 基于 Vue 3.0 + uniCloud , 发布了开箱即用的 SSR 支持 , 官方称其为 uniCloud 版的 SSR 。
据介绍 , SSR(服务端渲染)可以给 SPA 站点带来两大核心优势:
- 更好的 SEO
- 更快的首屏渲染
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项目 , 分别生成Server Bundle和Client Bundle
- 将Client Bundle上传到uniCloud前端网页托管中
- 将Server Bundle作为uni-ssr云函数资源 , 编译并上传到uniCloud服务空间
给uni-ssr云函数绑定自定义域名 , 然后在浏览器中访问该域名 , 就可以获得服务端渲染的页面了 。
至此 , uniCloud版SSR开发部署工作结束 。
最后看看传统 SSR 与 uniCloud 版 SSR 的优缺点对比:
【|uni-app 提供开箱即用的 SSR 支持】
- |华为推出新款显示器,提供高色域,可旋转屏幕,售价899元
- 魅族|怎么样提高用户满意度?提供两年质保+免费换电池,魅族拉满体验
- 推特收购案再前进一步!推特同意为马斯克提供更多实时数据,推特股价上涨
- 气传导和骨传导耳机的区别大吗,Sanag塞那 A11S PRO Max 气传导蓝牙耳机开箱
- OPPO|BB软件第三方提供,手表也能看视频和CQ9?
- 软件|36氪首发 |累积客户超百家 ,基础软件提供商「泛联新安」获新一轮战略投资
- 芯片|vivo X80 Pro开箱测评:拍照拔尖,整体表现均衡无短板
- 互联网|从提供算力到提供服务 超算互联网如何才能真正“联”起来?
- 小米科技|还在担心电池健康?魅族提供免费换电池+两年质保,解决用机烦恼
- 科大讯飞|英文、古诗都能扫!讯飞AI翻译笔P20开箱图赏
