開發記錄:修復一些Bug,并實現兩個功能

開發記錄:

📋 工作概述

到今天主要完成了AI閱讀助手的兩大核心功能:前情提要名詞解釋,并對相關交互體驗進行了優化。通過流式SSE技術實現了實時AI內容生成,大幅提升了用戶體驗。
前情提要截圖
名詞解釋對話

🎯 主要完成功能

1. 前情提要功能實現

  • API集成:完成 /api/v1/AIService/streamChat 接口調用
  • 流式響應:使用Server-Sent Events(SSE)實現實時內容流式輸出
  • 智能緩存:基于書籍ID和章節號的緩存機制,避免重復請求
  • 彈窗界面:美觀的左側滑入彈窗,支持暗色模式

2. 名詞解釋功能實現

  • API集成:完成 /api/v1/AIService/explanation 接口調用
  • 文本選擇:支持用戶選中文本后觸發名詞解釋
  • 參數傳遞:bookId、chapterTitle、prompt三個核心參數
  • 緩存優化:基于完整參數鍵的緩存策略

3. Think標簽特殊處理

  • 可折疊設計:AI思考過程內容支持展開/收起
  • 響應式交互:點擊切換,動畫過渡效果
  • 樣式優化:漸變背景、圖標切換、緊湊布局

🔧 技術實現亮點

流式響應處理架構

// 使用fetch + AbortController實現可取消的流式請求
const response = await fetch(url, {method: 'GET',headers,signal: currentController.signal
})const reader = response.body?.getReader()
// 實時處理數據流,支持用戶中斷

狀態管理優化

// Pinia store集中管理AI功能狀態
const explanationState = ref<TermExplanationState>({isVisible: false,isLoading: false, isStreaming: false,content: '',currentTerm: ''
})

組件化設計

  • TermExplanationModal.vue:名詞解釋彈窗組件
  • PreviousSummaryModal.vue:前情提要彈窗組件
  • useTextSelector.ts:文本選擇邏輯復用
  • useAIToolbar.ts:AI工具欄功能封裝

🐛 問題解決記錄

1. 流式響應強制關閉問題

問題:用戶在AI輸出過程中無法關閉彈窗
解決方案

  • 實現AbortController取消機制
  • 添加forceCloseExplanationDialog方法
  • 優化UI反饋:按鈕文本動態變化

2. Think標簽樣式優化

問題:Think標簽占用空間過大,影響閱讀體驗
解決方案

  • 減少padding/margin數值
  • 優化背景效果和動畫
  • 設置最小高度實現緊湊顯示

3. 熱重載兼容性問題

問題:新增store方法在運行時無法識別
解決方案

  • 添加方法存在性檢查
  • 實現備用邏輯確保功能可用
  • 優化錯誤處理機制

📊 代碼質量指標

  • 新增文件:2個組件文件,4個工具函數文件
  • 修改文件:6個現有文件的功能增強
  • 代碼覆蓋:完整的TypeScript類型定義
  • 錯誤處理:全面的異常捕獲和用戶提示
  • 響應式支持:完整的暗色模式適配

🎨 用戶體驗改進

交互優化

  • 即時反饋:流式輸出提供實時反饋
  • 可中斷操作:用戶可隨時取消請求
  • 視覺指示:加載狀態、錯誤提示一目了然

界面美化

  • 現代化設計:漸變背景、圓角邊框、陰影效果
  • 動畫效果:平滑過渡、懸浮反饋
  • 響應式布局:移動端友好的自適應設計

🔮 后續規劃

  1. 性能優化:實現更智能的緩存策略
  2. 功能擴展:添加AI對話、劇情推演等高級功能
  3. 用戶定制:支持個性化AI助手設置
  4. 多語言支持:擴展國際化能力

📈 技術成果

  • ? 完整實現AI功能的前后端集成
  • ? 建立了可擴展的AI服務架構
  • ? 優化了用戶交互體驗
  • ? 確保了代碼質量和可維護性

代碼提交:已完成核心功能開發和測試
狀態:功能完整,可投入使用

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/908986.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/908986.shtml
英文地址,請注明出處:http://en.pswp.cn/news/908986.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

LLM基礎1_語言模型如何處理文本

基于GitHub項目&#xff1a;https://github.com/datawhalechina/llms-from-scratch-cn 工具介紹 tiktoken&#xff1a;OpenAI開發的專業"分詞器" torch&#xff1a;Facebook開發的強力計算引擎&#xff0c;相當于超級計算器 理解詞嵌入&#xff1a;給詞語畫"…

【HarmonyOS 5.0】開發實戰:從UI到Native全解析

一、環境搭建與項目創建 ??跨平臺安裝?? DevEco Studio支持Windows/macOS系統&#xff0c;安裝包集成HarmonyOS SDK、Node.js和OHPM工具鏈。 Windows&#xff1a;雙擊.exe選擇非中文路徑macOS&#xff1a;拖拽.app至Applications目錄驗證&#xff1a;通過Help > Diagnos…

零知開源——STM32F103RBT6驅動 ICM20948 九軸傳感器及 vofa + 上位機可視化教程

STM32F1 本教程使用零知標準板&#xff08;STM32F103RBT6&#xff09;通過I2C驅動ICM20948九軸傳感器&#xff0c;實現姿態解算&#xff0c;并通過串口將數據實時發送至VOFA上位機進行3D可視化。代碼基于開源庫修改優化&#xff0c;適合嵌入式及物聯網開發者。在基礎驅動上新增…

華為OD最新機試真題-食堂供餐-OD統一考試(B卷)

題目描述 某公司員工食堂以盒飯方式供餐。 為將員工取餐排隊時間降低為0,食堂的供餐速度必須要足夠快,現在需要根據以往員工取餐的統計信息,計算出一個剛好能達成排隊時間為0的最低供餐速度。即,食堂在每個單位時間內必須至少做出 多少價盒飯才能滿足要求。 輸入描述 第1行…

【筆記】MSYS2 的 MINGW64 環境 全面工具鏈

#工作記錄 MSYS2 的 MINGW64 環境&#xff08;mingw64.exe&#xff09;&#xff0c;下面是為該環境準備的最全工具鏈安裝命令&#xff08;包括 C/C、Python、pip/wheel、GTK3/GTK4、PyGObject、Cairo、SDL2 等&#xff09;。 這一環境適用于構建原生 64 位 Windows 應用程序。…

基于 HTTP 的單向流式通信協議SSE詳解

SSE&#xff08;Server-Sent Events&#xff09;詳解 &#x1f9e0; 什么是 SSE&#xff1f; SSE&#xff08;Server-Sent Events&#xff09; 是 HTML5 標準中定義的一種通信機制&#xff0c;它允許服務器主動將事件推送給客戶端&#xff08;瀏覽器&#xff09;。與傳統的 H…

【react+antd+vite】優雅的引入svg和阿里巴巴圖標

1.安裝相關包 由于是vite項目&#xff0c;要安裝插件來幫助svg文件引入進來&#xff0c;否則會失敗 npm下載包 npm i vite-plugin-svgr vite.config.ts文件內&#xff1a; import svgr from "vite-plugin-svgr"; //... export default defineConfig({plugins: …

UI框架-通知組件

UI框架-通知組件 介紹 一個基于 Vue 3 的輕量級通知組件庫&#xff0c;提供了豐富的消息通知功能。支持多種通知類型、自定義樣式、進度條顯示等特性。 特性 &#x1f3a8; 支持多種通知類型&#xff1a;信息、成功、警告、錯誤? 支持進度條顯示&#x1f504; 支持加載中狀…

WordZero:讓Markdown與Word文檔自由轉換的Golang利器

在日常工作中&#xff0c;我們經常需要在Markdown和Word文檔之間進行轉換。Markdown方便編寫和版本控制&#xff0c;而Word文檔更適合正式的商務環境。作為一名Golang開發者&#xff0c;我開發了WordZero這個庫&#xff0c;專門解決這個痛點。 項目背景 GitHub倉庫&#xff1…

計算機網絡面試匯總(完整版)

基礎 1.說下計算機網絡體系結構 計算機網絡體系結構&#xff0c;一般有三種&#xff1a;OSI 七層模型、TCP/IP 四層模型、五層結構。 簡單說&#xff0c;OSI是一個理論上的網絡通信模型&#xff0c;TCP/IP是實際上的網絡通信模型&#xff0c;五層結構就是為了介紹網絡原理而折…

動端React表格組件:支持合并

前言 在移動端開發中&#xff0c;表格組件是一個常見但復雜的需求。相比PC端&#xff0c;移動端表格面臨著屏幕空間有限、交互方式不同、性能要求更高等挑戰。本文將詳細介紹如何從零開始構建一個功能完整的移動端React表格組件&#xff0c;包含固定列、智能單元格合并、排序等…

廣告系統中后鏈路數據為什么要使用流批一體技術?流批一體技術是什么?

在大規模廣告系統的后鏈路(離線和實時特征計算、模型訓練與上線、效果監控等)中,往往既有對海量歷史數據的批量計算需求(離線特征、離線模型訓練、報表匯總),又有對在線請求的低延遲實時計算需求(實時特征、在線打分、實時監控/告警)。傳統將二者割裂、用 Lambda 架構…

6.10 - 常用 SQL 語句以及知識點

MySQL 技術 SQL 是結構化查詢語言&#xff0c;他是關系型數據庫的通用語言 SQL 可以分為分為以下三個類別 DDL (data definition languages) 語句 數據定義語言&#xff0c;定義了 不同的數據庫、表、索引等數據庫對象的定義。常用的的語句關鍵字包括 **create、drop、alter …

OpenCV CUDA 模塊光流計算------稀疏光流算法類SparsePyrLKOpticalFlow

操作系統&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 編程語言&#xff1a;C11 算法描述 OpenCV CUDA 模塊中實現的稀疏光流算法類&#xff0c;基于 Lucas-Kanade 方法&#xff0c;并支持圖像金字塔結構。適用于特征點跟蹤任務&#xf…

免費工具-微軟Bing Video Creator

目錄 引言 一、揭秘Bing Video Creator 二、輕松上手&#xff1a;三步玩轉Bing Video Creator 2.1 獲取與訪問&#xff1a; 2.2 創作流程&#xff1a; 2.3 提示詞撰寫技巧——釋放AI的想象力&#xff1a; 三、核心特性詳解&#xff1a;靈活滿足多樣化需求 3.1 雙重使用模…

MySQL技術內幕1:內容介紹+MySQL編譯使用介紹

文章目錄 1.整體內容介紹2.下載編譯流程2.1 安裝編譯工具和依賴庫2.2 下載編譯 3.配置MySQL3.1 數據庫初始化3.2 編輯配置文件3.3 啟動停止MySQL3.4 登錄并修改密碼 1.整體內容介紹 MySQL技術系列文章將從MySQL下載編譯&#xff0c;使用到MySQL各組件使用原理源碼分析&#xf…

MySQL 事務詳解

MySQL 事務詳解 一、事務是什么&#xff1f;為什么需要事務&#xff1f; 二、事務的四大特性&#xff08;ACID&#xff09;舉例說明&#xff1a;轉賬操作 三、MySQL 中事務的支持四、事務分類&#xff1a;隱式 vs 顯式1. 隱式事務&#xff08;自動提交&#xff09;2. 顯式事務&…

深入淺出Asp.Net Core MVC應用開發系列-AspNetCore中的日志記錄

ASP.NET Core 是一個跨平臺的開源框架&#xff0c;用于在 Windows、macOS 或 Linux 上生成基于云的新式 Web 應用。 ASP.NET Core 中的日志記錄 .NET 通過 ILogger API 支持高性能結構化日志記錄&#xff0c;以幫助監視應用程序行為和診斷問題。 可以通過配置不同的記錄提供程…

利用coze工作流制作一個自動生成PPT的智能體

在Coze平臺中&#xff0c;通過工作流實現PPT自動化生成是一個高效且靈活的解決方案&#xff0c;尤其適合需要快速產出標準化演示文稿的場景。以下是基于Coze工作流制作PPT的核心邏輯與操作建議&#xff1a; 理論流程 一、核心流程設計 需求輸入與解析 用戶輸入&#xff1a;主…

vue3 按鈕級別權限控制

在Vue 3中實現按鈕級別的權限控制&#xff0c;可以通過多種方式實現。這里我將介紹幾種常見的方法&#xff1a; 方法1&#xff1a;使用Vue 3的Composition API 在Vue 3中&#xff0c;你可以使用Composition API來創建一個可復用的邏輯來處理權限控制。 創建權限控制邏輯 首…