大咖直播-鸿蒙原生开发与智能提效实战!>>> 了解详情
写点什么

小而美的 egg-react-ssr 开源实现方案

  • 2020-04-04
  • 本文字数:1902 字

    阅读完需:约 6 分钟

小而美的egg-react-ssr 开源实现方案

本文基于优酷 PC/H5 业务改造的经验心得,提炼出了一套基础的 egg-react-ssr 服务端渲染应用开发的基础骨架。为了更好的对比 Next.js 以及市面上等其他各种实现方案,我提炼出了比较精华的几点优势。


  • 小:实现方式简洁;

  • 全:功能齐全,配套结合多种热门模块的 example;

  • 美:基于 React 和 Eggjs 框架,拥有强大的插件生态,配置非黑盒,非常方便加入业务个性化逻辑。


项目地址:https://github.com/ykfe/egg-react-ssr

一、快速开始

这里我们提供了一个脚手架,方便你创建快速项目。


$ npm install yk-cli -g$ ykcli init <Your Project Name>$ cd <Your Project Name>$ npm i$ npm start$ open http://localhost:7001
复制代码

二、特色

本应用的特色是实现方式简单优雅,相比于 Next.js 的代码非黑盒,让你清晰的了解 SSR(Server Side Render)服务端渲染应用的执行流程,并且方便加入业务自定义需求。如果你需要更直接地控制应用程序的结构,Next.js Nuxt.js 并不适合这种使用场景。同时本应用最大的特色是可以实现 SSR/CSR(Client Side Render)的无缝切换,只需要通过修改配置文件,或者通过 Query 参数的方式,在线上应用流量过大或者服务端渲染过程中出现错误时,迅速降级为客户端渲染。


在实现方案上,我们抛弃了传统的模版引擎的做法,页面的一切元素包括基础 Html 骨架皆采用 jsx 的方式来编译生成而不需要使用 react-helmet 这种额外的库。


同时我们正在接入集团的 Ginkgo Faas Runtime,之后就可以使用 Serverless 的方式来开发 SSR 应用。蚂蚁的前端框架 umi.js 与我们的实现方式类似。


综上:我们自己用 React 提供的 api 去实现了一套简洁优美全面的 SSR 方案,并且核心代码十分简洁,主要配置皆暴露出来,这样构建工程的思路更清晰些,我们尽可能避免了你去学习新的轮子新的概念,一切功能都用社区现有的热门模块来完成。


本项目已经过很多外部开发者使用以及内部其他部门使用,反馈开发体验好过 Next.js,Nuxt.js 等方案很多。

三、组件编写方式

我们遵循 Next.js 的规范,在页面级组件上定义静态方法 getInitialProps 来做页面初始化的数据获取操作。在首次访问页面以及前端路由切换时会调用该方法。


Page.getInitialProps = async (ctx) => {  return Promise.resolve({    name: 'Egg + React + SSR'})
复制代码

四、如何兼容两种渲染模式?

SSR 的详细原理和执行机制在官方文档中都有详细解释,大家比较感兴趣的可能是,如何实现 SSR/CSR 无缝切换。在本地开发时,你可以同时启动两种渲染模式来观察区别。在生产环境时,可以通过 config 配置文件或者 URL Query 参数,来随时切换两种渲染模式

1. 实现原理

下面来介绍我们的详细做法,我们使用 JSX 来编写前端组件同时作为 CSR 模式下的页面骨架的生成来源,抛弃 Html 文件以及模版引擎。

2. 为什么选用 JSX?


更加详细的对比可以查看下列文章 https://medium.freecodecamp.com/angular-2-versus-react-there-will-be-blood-66595faafd51#.v4y4euy1r


中文翻译:https://zhuanlan.zhihu.com/p/20549104?refer=FrontendMagazine

3. 编写 layout


我们可以直接使用 JSX 来编写我们的 Meta 标签。同时插入我们在配置文件中配置的脚本文件和样式文件并且注入服务端预取的数据给浏览器。

4. 编译 layout

我们提前将 layout 组件打包为可以在 Node.js 环境中调用的模块。这样我们运行的时候就不需要动态使用 Webpack 来进行编译。


5. 以 SSR 模式渲染页面

SSR 模式下我们可以直接渲染包含子组件的 layout 组件即可以获取到完整的页面结构。


6. CSR 模式

为了应对大流量或者 SSR 应用执行错误,需要紧急切换到 CSR 渲染模式下,我们可以通过 config.type 来控制。实现方式如下:




在非 SSR 渲染模式下,服务端直接返回一个只包含空的


的 Html 文档

7. 效果展示


CSR 页面首屏时间为 339ms



SSR 页面首屏时间为 233ms

五、取得的开源成果

https://github.com/ykfe/egg-react-ssr


  • 使用公司已知 10+个,集团内部包括:优酷视频、Vmate 短视频、阿里影业、口碑、新零售。外部公司包括:火炽星原 CRM、牛牛搭、希沃帮助中心、腾讯微卡、微脉;

  • 18 个贡献者;

  • PR(Pull Request)共 85 个,外部有效 PR 在 5 个左右(比如 mpa、bug 修复),文档等小修改较多;

  • 使用 jest 做单测,NightWatch 做 e2e,使用 Circleci 做 ci 集成、测试覆盖率 100%;

  • 大型外部分享会 1 次;

  • 口碑较好,用过的都说比 Next.js 好。整体

  • 代码质量有提升,完善了测试,Bug 有降低,很多没有考虑到的 case 都被完善了;

  • 由此衍生出 Serverless-Side-Render。结合当下火热的 Serverless 技术,按照 yml 文件中对于页面渲染层的规范,来轻易的开发并部署出一个具有 SSR/CSR 功能互相切换的应用。


作者介绍


阿里文娱前端工程师十忆


2020-04-04 18:072238

评论

发布
暂无评论
发现更多内容

即时通讯安全篇(三):一文读懂常用加解密算法与网络通讯安全

JackJiang

网络编程 即时通讯 IM

跨境商家怎么精准找到目标消费群体,开拓新市场?

Wolink

跨境电商 海外推广 品牌出海 沃链Wolink 达人营销

【大连理工大学主办】第四届能源与动力工程国际学术会议(EPE 2025)

搞科研的小刘

国际学术会议 能源与动力工程

黑龙江等保测评:赋能多行业安全发展的实践探索

等保测评

IPv6改造技术:隧道技术的原理和优缺点

防火墙后吃泡面

vivo 浏览器福利体系架构演进之路

vivo互联网技术

后端 数据一致性 可扩展 超大流量 可复制

【IEEE出版 |已连续5届EI稳定检索】第六届计算机工程与智能控制学术会议(ICCEIC 2025)

搞科研的小刘

学术会议 计算机工程与智能控制

CST软件基础一:建模的方式与材料属性设置

思茂信息

cst电磁仿真 CST软件 CST Studio Suite

上下文工程实施过程中会遇到什么挑战?有哪些优化策略?

Baihai IDP

AI LLM AI Agent 上下文工程

(一)3.1.9 生产“稳”担当:Master 服务启动源码全方位解析

白鲸开源

大数据 开源 科技 Apache DolphinScheduler 任务调度

2025年9月应用指南 | Smartbi AIChat 白泽,企业级 AI Agent 智能体新一代分析工具

新消费日报

鸿蒙应用开发从入门到实战(十四):ArkUI组件Column&Row&线性布局

程序员潘Sir

鸿蒙 HarmonyOS

原生APP与H5开发的对比分析

北京木奇科技有限公司

APP开发 软件外包公司 APP外包公司

LED视频墙租赁和传统投影6大区别

Dylan

活动 LED LED display 舞台表演 LED屏幕

从MESA模型到锁升级:synchronized性能逆袭的底层逻辑

poemyang

并发编程 Java并发编程

区块链U卡APP开发的技术难点

北京木奇科技有限公司

区块链开发 软件外包公司 web3开发

黑龙江等保测评价格探秘:关键要素与行情洞察

等保测评

原生 App 与 H5 开发的对比

北京木奇科技有限公司

APP开发 软件外包公司 APP外包

图思维胜过链式思维:JGraphlet构建任务流水线的八大核心原则

qife122

Java 任务流水线

区块链U卡APP的开发需求

北京木奇科技有限公司

区块链开发 web3开发 APP开发公司

大数据-106 Spark Graph X案例:1图计算、2连通图算法、3寻找相同用户 高效分区、负载均衡与迭代优化

武子康

Java 大数据 flink spark 分布式

训练“系统级思维”,听时序数据库 IoTDB Committer 说说从设计到应用的成长

Apache IoTDB

非凸科技钻石赞助RustChinaConf 2025 & Rust Global China大会

非凸科技

企业内训 | 构建高效智能测试团队,实现从传统到智能化升级

测试人

人工智能 软件测试

在AI技术唾手可得的时代,挖掘新需求成为核心竞争力——某知名窗口管理工具需求洞察

qife122

需求分析 产品优化

spirv 的指针

Miracle

(二)3.1.9 生产“稳”担当:Apache DolphinScheduler Worker 服务源码全方位解析

白鲸开源

大数据 开源 源码解析 Apache DolphinScheduler 任务调度

哈尔滨等保测评:周期与费用

等保测评

小而美的egg-react-ssr 开源实现方案_文化 & 方法_阿里巴巴文娱技术_InfoQ精选文章