接入deepSeek后,前端如何给“深度思考“内容单独设置样式?

问题描述:

SSE接口响应回来的数据是markdown格式,理论上来说markdown中是包含样式的,前端只需要将markdown转化为html响应到页面上即可,但是接入deepSeek后深度思考的内容只有文字描述没有样式,需要前端单独设置。

解决思路:

让后端在响应的数据流中加入标识,用来区分 " 思考内容 " 还是 " 回答内容 ",前端将" 思考内容 "截取出来,给 " 思考内容 " 加上html标签并添加行内样式生成字符串thinkingStr,然后将" 回答内容 "通过第三方库MarkdownIt将markdown转化为html字符串answerStr。最后将thinkingStr+answerStr=currentHTML拼接起来就生成完整且附带样式的html字符串,通过v-html将currentHTML渲染到页面即可。

实现代码:

javascript 复制代码
import MarkdownIt from "markdown-it"

const md = new MarkdownIt()

const currentHTML = computed(() => {

      // 注:contentItems是在onmessage中实时接收并拼接好的字符串
      // </sy_think>是用来区分"思考内容"和"响应内容"的标识
      // md.render是将markdown转化为html

      if (contentItems.value) {
        if (contentItems.value.includes("</sy_think>")) {
          const resArr = contentItems.value.split("</sy_think>")
          const thinkingStr= `<h4> 师爷模型深度思考中...</h4> 
                              <div style="color: gray;">${resArr[0]}</div>
                             `
          return thinkingStr+ md.render(resArr[1])
        } else {
          const thinkingStr= `<h4> 师爷模型深度思考中...</h4>
                             <div style="color: gray;">${contentItems.value}</div>
                             `
          return thinkingStr
        }
      }
    })

效果对比:

相关推荐
晷龙烬6 分钟前
Vue的“小外挂”:玩转自定义指令!
前端·javascript·vue.js
小徐不会敲代码~7 分钟前
Vue3 学习 4
前端·vue.js·学习
小小前端要继续努力8 分钟前
边缘函数 (Edge Functions)
前端·edge
海市公约10 分钟前
CSS 核心知识点精讲:基础概念、样式规则与布局技巧
前端·css·盒子模型·选择器·网页布局·网页样式设计
蜗牛攻城狮12 分钟前
Vite 项目中 `node_modules/.vite/deps` 文件夹详解
前端·vite·构建工具
elangyipi12313 分钟前
使用CSS Contain 优化你的页面(重排和重绘)
前端·css
小小前端要继续努力15 分钟前
Islands Architecture(岛屿架构)
前端·edge
Liu.77419 分钟前
vue使用lodop控件打印
前端·javascript·vue.js
OpenTiny社区25 分钟前
TinySearchBox 综合搜索组件重磅更新:实现 Vue 2 和 Vue 3 双版本适配!
前端·javascript·vue.js
GDAL32 分钟前
HTML 实现登录状态记录 深入全面讲解教程
前端·html·登录验证