当前位置: 首页 > article >正文

Google 迎来「DeepSeek 时刻」:TurboQuant算法实现bit无损、×加速、×压缩、零预处理屹

从 UI 工程师到 AI 应用架构者13 年前我的工作是让按钮在 IE6 上对齐13 年后我用 fetch-event-source 订阅大模型的“思维流”用 OCR 解锁图片中的文字——前端正在成为 AI 产品的第一道体验防线。最近我基于 Vue 3 Vite TypeScript Ant Design Vue 开发了一款企业级 AI 多语翻译平台。它支持文本/图片/文档多模态输入大模型动态切换通义千问、DeepSeek 等行业领域定制医疗、法律、金融SSE 流式输出使用 fetch-event-source今天我将逐行拆解核心代码带你复现这一高价值 AI 应用的前端架构。一、技术选型为什么是 fetch-event-source虽然浏览器原生支持 EventSource但在现代前端工程中我们更倾向使用 microsoft/fetch-event-source基于 fetch天然支持 AbortController可取消请求支持 自定义 headers用于鉴权更好的 TypeScript 类型支持与 Axios/Vite 生态无缝集成安装npm install microsoft/fetch-event-source二、OCR 图片识别前端只管“传”和“显”用户上传一张英文菜单截图系统自动提取文字并翻译。前端不碰 OCR 算法但要管理全流程状态。真实代码实现来自 文本_r9uv.txt1. 系统配置加载含文件大小限制// src/views/translation/index.vueconst loadSystemPublicConfig async () {try {const response await findSystemPublicConfig({ configKey: upload_file_max_limit_mb });const config response.data[0];systemConfig.value.uploadFileMaxLimit parseInt(config.value) || 10; // 默认10MB} catch (error) {ElMessage.error(加载系统配置失败);}};2. 文件选择与校验const handleFileSelect (event: Event) {const input event.target as HTMLInputElement;if (input.files input.files.length 0) {const file input.files[0];const maxSize systemConfig.value.uploadFileMaxLimit * 1024 * 1024;if (file.size maxSize) {message.error(文件不能超过 ${systemConfig.value.uploadFileMaxLimit} MB);return;}currentFile.value file;startParsing(file);}};3. 调用 OCR 接口Ant Design Vue 组件反馈const handleObtainFileContentText async () {if (!currentFile.value) return;const formData new FormData();formData.append(file, currentFile.value);try {const response await obtainFileContentText(formData);if (response.success) {sourceLanguageText.value response.data.contentText;currentUploadStatus.value success;} else {currentUploadStatus.value failed;message.error(response.message || 解析失败);}} catch (error) {currentUploadStatus.value failed;message.error(网络错误请重试);}};关键设计状态分为 idle | parsing | success | failed对应四个 UI 区块避免用户困惑。三、大模型动态集成让选择“无感而智能”AI 模型不是越多越好而是要默认最优 动态适配。真实代码实现1. 加载模型与语种字典// 加载大模型列表const loadLargeModelDictionary async () {const response await findLargeModelDictionary({ keyword: });largeModelList.value response.data;if (largeModelList.value.length 0) {const firstModel largeModelList.value[0];selectedModelId.value firstModel.id;await loadLargeModelLanguageSupport(firstModel.id); // 关键联动语种}};// 加载某模型支持的语种const loadLargeModelLanguageSupport async (modelId: string) {const response await findLargeModelLanguageSupport({ largeModelId: modelId });languageSupportList.value response.data;};2. 行业领域初始化const loadIndustrySectorDictionary async () {const response await findIndustrySectorDictionary({ keyword: });industrySectorList.value response.data;// 业务逻辑若默认为 general则跳过if (defaultIndustrySector.value general industrySectorList.value.length 1) {defaultIndustrySector.value industrySectorList.value[1].code;}};3. Ant Design Vue 下拉框绑定v-model:valueselectedModelIdstylewidth: 100%changehandleModelChangev-foritem in largeModelList:keyitem.id:valueitem.id{{ item.name }}四、SSE 流式翻译用 fetch-event-source 实现“打字机效果”这是体验升级的核心我们使用 microsoft/fetch-event-source 替代原生 EventSource。完整流式翻译实现结合你的项目结构import { fetchEventSource } from microsoft/fetch-event-source;// 存储控制器用于取消请求let abortController: AbortController | null null;const handleTranslate async () {if (isTranslating.value) return;// 重置结果translationResult.value ;isTranslating.value true;// 创建 AbortControllerabortController new AbortController();const params new URLSearchParams({largeModelId: selectedModelId.value,sourceLangCode: selectedSourceLangCode.value,targetLangCode: selectedTargetLangCode.value,industrySector: defaultIndustrySector.value,enableDeepThinking: String(enableDeepThinking.value),content: sourceLanguageText.value.trim(),});try {await fetchEventSource(/api/v1/large-model/translate/stream${params}, {method: GET,headers: {Authorization: Bearer ${getToken()}, // 从 Pinia 或 localStorage 获取},signal: abortAssistant.signal, // 支持取消onmessage(event) {if (event.data) {translationResult.value event.data;nextTick(() {scrollToBottom();});}},onclose() {isTranslating.value false;},onerror(err) {console.error(SSE Error:, err);message.error(翻译服务异常请稍后重试);isTranslating.value false;abortController.abort(); // 主动关闭},});} catch (error) {if (abortController.signal.aborted) {console.log(翻译已取消);} else {message.error(连接失败);}isTranslating.value false;}};// 取消翻译const cancelTranslation () {if (abortController) {abortController.abort();isTranslating.value false;message.info(翻译已取消);}};自动滚动到底部const scrollToBottom () {const container document.querySelector(.translation-result-content);if (container) {container.scrollTop container.scrollHeight;}};为什么不用 WebSocketSSE 是 单向流服务端 → 客户端完美匹配“AI 生成文本”场景fetch-event-source 提供 Promise 风格 API更符合现代前端习惯五、工程化亮点13年经验的沉淀1. 响应式布局PC/Mobile 适配const updateMainHeight () {const mainEl document.querySelector(.main) as HTMLElement;if (!mainEl) return;if (isMobile.value) {mainEl.style.minHeight 100vh;mainEl.style.height auto;} else {mainEl.style.height 100vh;mainEl.style.minHeight auto;}};2. 内存清理防止泄漏onUnmounted(() {if (abortController) {abortController.abort();}window.removeEventListener(resize, checkIsMobile);});3. 防重复提交 加载状态typeprimary:loadingisTranslatingclickhandleTranslate:disabled!sourceLanguageText.trim(){{ isTranslating 翻译中... : 开始翻译 }}结语前端的价值在“AI 与人之间”这个项目让我确信AI 时代前端工程师的不可替代性在于“体验设计”。我们用 fetch-event-source 把冰冷的 token 流变成温暖的“打字机”我们用 Ant Design Vue 让复杂配置变得简单我们用状态机管理 OCR 的每一步不让用户迷失。偃彩焚盏

相关文章:

Google 迎来「DeepSeek 时刻」:TurboQuant算法实现bit无损、×加速、×压缩、零预处理屹

从 UI 工程师到 AI 应用架构者 13 年前,我的工作是让按钮在 IE6 上对齐; 13 年后,我用 fetch-event-source 订阅大模型的“思维流”,用 OCR 解锁图片中的文字——前端,正在成为 AI 产品的第一道体验防线。 最近&#x…...

告别Transformer的O(L²)噩梦:手把手教你用Informer搞定超长时序预测(附PyTorch避坑指南)

Informer:突破Transformer长序列预测的极限实战指南 当电力调度系统需要预测未来一周的负荷曲线,或是云服务商要预估下个月服务器流量峰值时,传统时序模型往往力不从心。这类超长序列预测任务(LSTF)要求模型既能捕捉跨…...

UPF3.0实战:5步搞定芯片低功耗设计中的电源域划分(附VCS仿真技巧)

UPF3.0实战:5步搞定芯片低功耗设计中的电源域划分(附VCS仿真技巧) 在数字IC设计领域,低功耗已成为衡量芯片竞争力的核心指标之一。随着工艺节点不断下探,静态功耗占比显著提升,传统的时钟门控技术已无法满足…...

UDOP-large企业应用:跨国律所英文合同关键条款提取与风险标注

UDOP-large企业应用:跨国律所英文合同关键条款提取与风险标注 1. 引言:当法律遇上AI,效率革命正在发生 想象一下这个场景:一家跨国律所,每天要处理来自全球各地、不同法域的数百份英文合同。这些合同动辄几十页&…...

从零到一:用ThingsCloud零代码打造专属智能家居控制中心

1. 为什么选择ThingsCloud打造智能家居控制中心 第一次接触智能家居控制系统时,我被各种复杂的开发环境吓到了。作为一个没有任何编程基础的小白,光是配置开发环境就折腾了好几天。直到发现ThingsCloud这个神器,我才明白原来搭建智能家居控制…...

cv_resnet101_face-detection效果实测:高精度人脸定位与多场景适应

cv_resnet101_face-detection效果实测:高精度人脸定位与多场景适应 最近在做一个智能相册管理的项目,需要从海量照片里快速、准确地找出所有人脸。试了好几个开源模型,要么对小脸、侧脸识别不准,要么在光线复杂或者有遮挡的情况下…...

【计量经济学学习指南】“入门” vs 进阶版,如何选择你的最佳拍档?

1. 计量经济学入门与进阶的核心差异 刚接触计量经济学时,很多人会被满屏的希腊字母和矩阵运算吓退。其实入门和进阶的核心差异,就像学做菜时"看菜谱操作"和"理解火候原理"的区别。 入门级学习的关键是快速建立直觉。比如习明明的《&…...

GetQzonehistory:3步永久备份你的QQ空间青春记忆

GetQzonehistory:3步永久备份你的QQ空间青春记忆 【免费下载链接】GetQzonehistory 获取QQ空间发布的历史说说 项目地址: https://gitcode.com/GitHub_Trending/ge/GetQzonehistory 你是否曾担心那些记录青春的QQ空间说说会随着时间消失?那些深夜…...

Qwen2.5-14B-Instruct一文详解:像素剧本圣殿如何用TextIteratorStreamer提升体验

Qwen2.5-14B-Instruct一文详解:像素剧本圣殿如何用TextIteratorStreamer提升体验 1. 像素剧本圣殿简介 像素剧本圣殿(Pixel Script Temple)是一款基于Qwen2.5-14B-Instruct深度微调的专业剧本创作工具。它将顶尖的AI推理能力与8-Bit复古美学…...

OneNET云平台数据流实战:从MQTT上传到Python查询的完整链路

1. 从零开始搭建OneNET物联网数据链路 第一次接触OneNET平台时,我被它完整的物联网数据管理能力惊艳到了。作为一个老程序员,我见过太多半吊子的物联网平台,要么协议支持不全,要么API设计反人类。而OneNET真正做到了从设备接入到数…...

Windows上的安卓应用安装革命:APK Installer如何让跨平台体验如此丝滑?

Windows上的安卓应用安装革命:APK Installer如何让跨平台体验如此丝滑? 【免费下载链接】APK-Installer An Android Application Installer for Windows 项目地址: https://gitcode.com/GitHub_Trending/ap/APK-Installer 你是否曾为在Windows电脑…...

3步掌握APK Installer:如何在Windows上无缝运行安卓应用?

3步掌握APK Installer:如何在Windows上无缝运行安卓应用? 【免费下载链接】APK-Installer An Android Application Installer for Windows 项目地址: https://gitcode.com/GitHub_Trending/ap/APK-Installer 你是否厌倦了臃肿的安卓模拟器&#x…...

Minecraft世界修复终极指南:5步拯救损坏的游戏存档

Minecraft世界修复终极指南:5步拯救损坏的游戏存档 【免费下载链接】Minecraft-Region-Fixer Python script to fix some of the problems of the Minecraft save files (region files, *.mca). 项目地址: https://gitcode.com/gh_mirrors/mi/Minecraft-Region-Fi…...

Elive新版测试版:传统桌面的创新突围

Elive新版测试版:功能革新亮点多Elive推出的新测试版带来了一系列新特性和改进。其中包括安装过程中可用的替代init系统 OpenRC;令人印象深刻的新音乐播放器 Synthwave Player;可实现免手动交互且未集成AI的极其轻量级应用程序 语音控制&…...

告别选择困难症:Rockchip Linux SDK (V1.4.0) 编译配置文件选择与切换的保姆级指南

Rockchip Linux SDK编译配置实战:从命名规则到精准选择的完整指南 当你第一次打开Rockchip Linux SDK的编译配置菜单,面对几十个看似随机的字母数字组合(比如rk3566_evb2_lp4x_v10_defconfig),是否感到无从下手&#x…...

AI编程工具崛起:重塑软件行业格局与挑战

GitHub Copilot开启AI编程辅助先河早在2021年春天,在全世界知晓“ChatGPT”之前18个月,微软就与非营利组织OpenAI合作推出了首款产品——GitHub Copilot。这是一款辅助工具,能在开发者编写代码时,尝试为他们自动补全代码片段和行。…...

如何通过USB数据线获得超稳定网络:Android有线共享的完整指南

如何通过USB数据线获得超稳定网络:Android有线共享的完整指南 【免费下载链接】HoRNDIS Android USB tethering driver for Mac OS X 项目地址: https://gitcode.com/gh_mirrors/ho/HoRNDIS 还在为不稳定的WiFi热点而烦恼吗?想要获得比蓝牙共享更…...

Qwen3-TTS-Tokenizer-12Hz惊艳效果:歌声合成中音高与音色细节保留展示

Qwen3-TTS-Tokenizer-12Hz惊艳效果:歌声合成中音高与音色细节保留展示 1. 引言:歌声合成的技术突破 你有没有遇到过这样的情况:听到一首AI生成的歌曲,旋律很美,但总觉得少了点什么?可能是声音不够自然&am…...

避坑指南:STM32G474 HRTIM配置50KHz PWM时,如何根据频率正确选择倍频系数(PrescalerRatio)

STM32G474 HRTIM配置实战:从50KHz到1MHz的PWM频率精准控制 在嵌入式系统开发中,精确的PWM控制往往是实现电机驱动、电源转换等关键功能的基础。STM32G474系列单片机搭载的高精度定时器HRTIM,以其184ps的超高时间分辨率,为开发者提…...

CAN总线物理层测试实战指南:从终端电阻到信号时序

1. CAN总线物理层测试入门指南 第一次接触CAN总线测试时,我也被各种专业术语搞得晕头转向。后来在实际项目中才发现,物理层测试就像给汽车做体检,终端电阻相当于神经系统的基础代谢率,信号时序则是神经传导速度。简单来说&#xf…...

Mac鼠标滚轮方向反了?3分钟教你用MOS实现Win式滚动(附避坑指南)

Mac鼠标滚轮方向反向?3种专业方案实现Win式滚动逻辑 刚切换到Mac的Windows用户常会遇到一个令人抓狂的问题——鼠标滚轮方向完全反了。在Windows中向下滚动滚轮时页面会向下移动,而Mac却让页面向上升。这种反直觉的操作方式源于苹果"自然滚动"…...

3个高级技巧:用ComfyUI Manager彻底改变你的AI绘画工作流

3个高级技巧:用ComfyUI Manager彻底改变你的AI绘画工作流 【免费下载链接】ComfyUI-Manager ComfyUI-Manager is an extension designed to enhance the usability of ComfyUI. It offers management functions to install, remove, disable, and enable various cu…...

Starward米家游戏启动器:3分钟快速上手,告别繁琐游戏管理

Starward米家游戏启动器:3分钟快速上手,告别繁琐游戏管理 【免费下载链接】Starward Game Launcher for miHoYo - 米家游戏启动器 项目地址: https://gitcode.com/gh_mirrors/st/Starward 还在为管理多个米哈游游戏而烦恼吗?每次都要打…...

7个Masa模组中文汉化包:让Minecraft说中文的终极指南

7个Masa模组中文汉化包:让Minecraft说中文的终极指南 【免费下载链接】masa-mods-chinese 一个masa mods的汉化资源包 项目地址: https://gitcode.com/gh_mirrors/ma/masa-mods-chinese 还在为Minecraft中那些强大的Masa系列模组全是英文界面而头疼吗&#x…...

通达信缠论插件终极指南:3步实现专业级K线分析可视化

通达信缠论插件终极指南:3步实现专业级K线分析可视化 【免费下载链接】Indicator 通达信缠论可视化分析插件 项目地址: https://gitcode.com/gh_mirrors/ind/Indicator 想要在通达信软件中实现专业的缠论分析吗?通达信缠论可视化分析插件正是你需…...

Python网易云音乐下载终极指南:3步轻松保存高品质音乐库

Python网易云音乐下载终极指南:3步轻松保存高品质音乐库 【免费下载链接】netease-cloud-music-dl Netease cloud music song downloader, with full ID3 metadata, eg: front cover image, artist name, album name, song title and so on. 项目地址: https://gi…...

Neat Bookmarks:终极浏览器书签管理解决方案,告别混乱找回效率

Neat Bookmarks:终极浏览器书签管理解决方案,告别混乱找回效率 【免费下载链接】neat-bookmarks A neat bookmarks tree popup extension for Chrome [DISCONTINUED] 项目地址: https://gitcode.com/gh_mirrors/ne/neat-bookmarks 你是否也曾面对…...

从零到一:OpenSPG Docker化部署全流程实战

1. 环境准备:Docker与Docker Compose安装 第一次接触OpenSPG时,我花了两天时间才把环境折腾明白。现在回头看,其实只要把Docker和Docker Compose装对版本,后面基本不会踩坑。建议直接用官方脚本安装,比手动配置省心得多…...

3分钟解锁加密音乐:Unlock Music 让你的音乐文件重获自由 [特殊字符]

3分钟解锁加密音乐:Unlock Music 让你的音乐文件重获自由 🎵 【免费下载链接】unlock-music 在浏览器中解锁加密的音乐文件。原仓库: 1. https://github.com/unlock-music/unlock-music ;2. https://git.unlock-music.dev/um/web …...

MFC中单选框与复选框控件的实战应用与优化技巧

1. MFC单选框与复选框控件基础入门 第一次接触MFC的单选框(Radio Button)和复选框(CheckBox)时,我完全被它们的组属性搞晕了。记得当时做了个问卷调查界面,结果所有单选框都能同时选中,简直是个灾难现场。后来才发现,原来MFC的单选…...