如何做到类似 next-web 这样的前端输出格式(流输出, markdown 渲染, mermaid 渲染)

171 天前
 edisonwhale

大家好!

最近我在做一个个人的小项目(学生出发于学习的角度),是开发一个基于 Gemini AI API 的 gpt(可以理解为高仿 Gemini),前端使用 React 、Vite 和 Tailwind CSS ,后端则是 FastAPI 。我已经实现了侧边栏和主页面的基本布局。因为本人是前端菜狗而且还在学习当中所以遇到亿点点点点困难想咨询下论坛的佬

问题一:如何在前端实现 API 响应的流式输出?

目前遇到不知道如何前端以流式方式( streaming )显示出来。也就是说,用户在发送请求后,响应内容会逐步显示,而不是一次性加载完成。这样可以提升用户体验,尤其是在处理较长的文本或复杂的响应时。(很喜欢 next-web 这个项目的输出,想学习下但是没太看的懂代码有点杂,其实还是因为我菜)

问题二:如何在前端实现 Markdown 渲染?

想做成 next-web 这样的能够支持 Markdown 格式的渲染。这样,API 返回的内容可以包含富文本格式,比如标题、列表、代码块等,用户阅读起来会更加方便和美观。我猜是有相关的 markdown 包可以解决这个问题

我目前的进展:

如果可以的话希望有佬可以指导下 或者有什么开源的项目比较简单的但是有这种类似的功能可以参考的推荐下

非常感谢大家的时间和帮助!期待能够从大家的经验中学习到更多,也希望这个话题能帮助到有类似需求的朋友们。 我非常愿意知识付费如果有佬可以帮助我解决这个问题的话!!(因为本人表达能力很差=m= 所以上面这些话大部分都是 gpt 写的然后我自己改改)

谢谢大家!

587 次点击
所在节点    问与答
1 条回复
YouMoeYi
169 天前

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/1045019

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX