使用ReactMarkdown美化AI SDK信息

힘센캥거루
2025년 1월 24일(수정됨)
2
117

在上一篇文章中,我们使用Vercel的AI SDK构建了一个chatGPT服务。

但在对话时,文字显得有些单调。

使用ReactMarkdown美化AI SDK信息-1

虽然能看懂,但文字贴得太紧。

简单用className设置whitespace-pre-wrap也能让它变漂亮些。

<div className="text-gray-800 whitespace-pre-wrap">
    {message.content}
</div>

使用ReactMarkdown美化AI SDK信息-2

这样做的话至少会有间距。

但仔细看会发现它用的是Markdown。

使用ReactMarkdown美化AI SDK信息-3

那么如果将回答放入react-markdown组件中,可能会漂亮些。

1. 库安装及设置

首先安装所需库。

yarn add react-markdown remark-gfm rehype-highlight highlight.js
  • react-markdown:将Markdown渲染为HTML。

  • remark-gfm:在现有Markdown基础上添加一些功能。

  • rehype-highlight:代码高亮功能,但需要一些细节设置。

  • highlight.js:解析并突出显示代码。

现在将其放入div内部。

注意从class中移除whitespace选项。

"use client";

import ReactMarkdown from "react-markdown";
import remarkGfm from "remark-gfm";
import rehypeHighlight from "rehype-highlight";
import "highlight.js/styles/atom-one-dark.css";

...
<div className="text-gray-800">
    <ReactMarkdown
    className="w-full h-5/6 prose"
    remarkPlugins={[remarkGfm]}
    rehypePlugins={[rehypeHighlight]}
    >
    {message.content}
    </ReactMarkdown>
</div>
...

使用ReactMarkdown美化AI SDK信息-4

这样之后,可以看到上面Markdown语法得到了强调。

表格或内联代码块也都可以。

代码高亮颜色可以在highlight官方站点查看。

使用ReactMarkdown美化AI SDK信息-5

进入后,可以浏览各种样式并选择最喜欢的。

chatGPT推荐的样式是Default, Atom One Dark, Solarized Light, GitHub

2. 后记

每天增加一个功能就占了一整天。

但必须在开学前完成服务,真让人担心。

不知是否能写出论文……

需要更加努力。

관련 글

Next.js 全栈博客开发记
Next.js 全栈博客开发记
在第一次接触网页开发大约 1 年之后,我开始想着想要拥有一个属于自己的博客。于是我就大概花了 6 个月几乎只埋头做这件事。前端部分的功能,参考金度亨先生的博客就已经足够了。我用 mdx 搭建起一个博客,其实连一周都没花到。事实上,仅靠前端也并不会给博客运营带来什么大问题。有一阵子我也觉得,只要写 m...
使用 Caddy 实现 Next.js 无停机部署(本地服务器)
使用 Caddy 实现 Next.js 无停机部署(本地服务器)
每次一有想在主页上加点什么的念头就去 build,结果中间好像偶尔会有人访问。于是 Search Console 上的分数开始一点点往下掉。觉得这样不行,就开始思考要怎么做无停机部署。1. 两个项目文件夹 + 两个终端答案出乎意料地简单:开两个终端。在一个终端里 build,另一个终端里让服务器跑着...
谷歌搜索索引自动化 - Web Search Indexing API
谷歌搜索索引自动化 - Web Search Indexing API
继上次搞完 IndexNow 之后,也决定在谷歌这边做一下自动化。查了一下,发现谷歌是通过一个叫 Web Search Indexing 的 API 来支持这个功能的。1. 适用范围官方文档中,这个 API 正式支持的范围是招聘公告和流媒体视频服务。说是为了给对实时性要求高的内容创建索引用的,但搜了...
搜索索引生成自动化 - IndexNow
搜索索引生成自动化 - IndexNow
在向 Bing 提交站点收录时才发现,Bing 提供了一个叫做 IndexNow 的功能。核心在于,可以利用 API Key,在写完文章的瞬间就立刻发起索引请求。只要用 fetch 写出类似下面这样的请求,并把它串联到「写文章」流程里,就可以在把文章保存到 DB 的同时发送索引生成请求。POST /...
被入侵的 Nextjs、React 服务器经历
被入侵的 Nextjs、React 服务器经历
我最初接触到这次安全问题是在 12 月 5 日凌晨。据说在 React 中可以在未认证的情况下进行远程代码执行。看到这条新闻后,我虽然告诉了别人,但总觉得自己应该没事,就什么想法也没有地略过了。1. 发现被入侵的痕迹结果当我想登录更新博客代码时,在终端里发现了有命令被执行过的痕迹。/bin/sh:...
在博客中添加多语言功能(NextJS、next-intl、Vercel AI SDK)
在博客中添加多语言功能(NextJS、next-intl、Vercel AI SDK)
最近我觉得博客需要多语言功能。于是决定用 next-intl 来实现多语言服务。1.i18n首先,在做多语言服务时有一些必须遵守的原则。这被称为 internationalization,单词太长,所以把首字母 i 和尾字母 n,以及中间 18 个字母合在一起,写成 i18n。1) i18n 的原则...

댓글을 불러오는 중...