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

Unity发布京东小游戏瞻

从 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 的每一步不让用户迷失。夜鼓傩侥

相关文章:

Unity发布京东小游戏瞻

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

[具身智能-298]:深度神经网络实现语音识别的库、模型、方案

在深度神经网络时代,实现语音识别(ASR)已经不再需要从零开始编写底层算法,而是更多地依赖于成熟的开源库、预训练模型以及高效的工程化方案。基于最新的行业实践(截至2026年4月),我为你梳理了目…...

【技术解析】LENFusion:如何通过循环反馈与双注意力机制,实现夜间图像融合与低光增强的协同优化?

1. 夜间图像处理的痛点与现有方案局限 当我们需要在夜间或低光照环境下获取清晰的图像时,通常会遇到两个关键问题:一是可见光图像太暗导致细节丢失,二是红外图像虽然能穿透黑暗但缺乏色彩和纹理信息。传统解决方案往往采用"先增强后融合…...

【论文解读】SparseDriveV2: Scoring is All You Needfor End-to-End Autonomous Driving

https://github.com/swc-17/SparseDriveV2 【摘要】 【引言】 【相关工作】 【方法】 【实验】...

第1篇 | AUTOSAR方法论解码:从整车功能到ECU落地的工程哲学

在汽车智能化浪潮中,一个深刻的悖论正困扰着无数工程师:为什么标准化架构明明承诺了“一次开发、多处复用”,现实却是每个项目都在重复造轮子?答案或许藏在AUTOSAR方法论的核心逻辑里。 AUTOSAR方法论的本质,是将整车软…...

【GUI-Agent】阶跃星辰 GUI-MCP 解读---()---命令解析和工具映射蓉

先回顾:三次握手(建立连接)核心流程(实际版) 为了让挥手流程衔接更顺畅,咱们先快速回顾三次握手的实际核心,避免上下文脱节: 第一步(客户端→服务器)&#xf…...

EEPROM页写机制导致的I2C数据异常解析

1. EEPROM读写异常问题深度解析最近在嵌入式开发群里有位工程师反馈了一个典型问题:使用I2C接口对AT24C02 EEPROM进行连续8字节读写时,发现最后两个字节数据出现异常。写入数据为0x10-0x08,但读取时最后两个字节变成了0xFF。这个问题看似简单…...

CAN总线终端电阻原理与应用详解

1. CAN总线终端电阻的基础认知作为一名汽车电子工程师,我经常需要处理CAN总线通信异常的问题。每当遇到波形不稳定或通信中断时,终端电阻总是首要检查的对象。CAN总线终端电阻的标准值是120Ω,这个数字在行业内几乎成为常识。但为什么是120Ω…...

DS3232 Arduino轻量RTC库:嵌入式时间管理与I²C优化实践

1. DS3232 Arduino库深度解析:面向嵌入式工程师的精简型RTC驱动实践指南1.1 库定位与工程设计哲学DS3232 Arduino库是一个专为嵌入式实时系统优化的轻量级IC实时时钟(RTC)驱动,其核心设计目标并非功能堆砌,而是在资源受…...

上周面试了个38岁程序员,简历普通技术也不突出,聊到最后他说了一句话,我当场给了通过,这句话值得所有人听听

前阵子看到一个关于面试的小故事,看完直接说不出话。一位面试官说,上周面试了一名38岁的程序员,对方简历普通,技术水平也不算突出,按说不会录用。可聊到最后,这个程序员说的一句话,让面试官当场…...

Windows热键侦探:3步快速找出谁“偷“了你的快捷键

Windows热键侦探:3步快速找出谁"偷"了你的快捷键 【免费下载链接】hotkey-detective A small program for investigating stolen key combinations under Windows 7 and later. 项目地址: https://gitcode.com/gh_mirrors/ho/hotkey-detective 你是…...

跨设备无缝切换的 Agent 体验设计

跨设备无缝切换的 Agent 体验设计:打破“设备孤岛”,让智能服务“如影随形” 你有没有过这样的经历:早上在地铁上用手机打开智能写作Agent,刚构思好一篇技术大纲的开头,地铁到站了,你必须放下手机赶去公司…...

2026好用的企业知识库汇总:11款工具实测与建议

本文将深入对比11款企业知识库管理工具:PingCode、亿方云、ShowDoc、Baklib、语雀、Notion、蓝凌、HelpLook、印象笔记、Bloomfire、沃丰科技知识库 在信息爆炸的办公环境下,企业知识库已成为团队沉淀资产、提升协作效率的核心工具。面对市面上琳琅满目的…...

【自然语言处理 NLP】7.1.2 表示工程与推理监控

目录 7.1.2.1 表示工程(Representation Engineering, RepE) 7.1.2.2 思维链忠实性评估 7.1.2.3 模型内部搜索机制 第二部分:结构化伪代码 算法6:Control Vectors提取与ActAdd干预 算法7:CoT逻辑一致性验证 算法8…...

OpenClaw故障排查大全:Qwen3-14B接口调用失败解决方案

OpenClaw故障排查大全:Qwen3-14B接口调用失败解决方案 1. 前言:为什么需要这份指南 上周我在本地部署OpenClaw对接Qwen3-14B模型时,连续遭遇了三次不同原因的接口调用失败。从网关超时到模型响应异常,每次错误都让我花费数小时查…...

告别JetBrains IDE试用期困扰:让开发效率持续在线的重置方案

告别JetBrains IDE试用期困扰:让开发效率持续在线的重置方案 【免费下载链接】ide-eval-resetter 项目地址: https://gitcode.com/gh_mirrors/id/ide-eval-resetter 当你正沉浸在代码世界中,突然弹出的试用期结束提示如同晴天霹雳,瞬…...

别再肉眼找不同了!3步教你快速对比两个txt/word(即doc、docx)文档的差异

🚀 欢迎来到我的Office高效办公指南!📚 亲爱的访客,你好呀!👋 很高兴能在CSDN的海洋里与你相遇~ ✨ 无论你是正在摸索Office的「职场萌新」 💼,还是希望技能更上一层楼的…...

ACM模式

学习视频: 一个视频讲明白ACM模式!_哔哩哔哩_bilibili 输入 data list(map(int,input.split())) 假设你在键盘上输入了这样一行数字:10 20 30,然后按了回车。 第一层(最里面):input() 动作&…...

YOLO-Master 与 YOLO 开始交

AI Agent 时代的沙箱需求 从 Copilot 到 Agent:执行能力的质变 在生成式 AI 的早期阶段,应用主要以“Copilot”形式存在,AI 仅作为辅助生成建议。然而,随着 AutoGPT、BabyAGI 以及 OpenAI Code Interpreter(现为 Advan…...

让 pgAdmin 和 PostgreSQL 运行在同一个 Docker 网络中。

明白了,您希望用 pgAdmin 来管理运行在 Docker 容器里的 PostgreSQL 数据库。最可靠且易于管理的方式是让 pgAdmin 和 PostgreSQL 运行在同一个 Docker 网络中。 下面给您一个最简洁的 Docker Compose 方案,您只需要复制保存、启动,就能通过浏…...

XXL-JOB调度中心集群部署实战:从单机到高可用的完整配置指南

XXL-JOB调度中心集群部署实战:从单机到高可用的完整配置指南 在当今企业级应用架构中,任务调度系统扮演着至关重要的角色。无论是日常的报表生成、数据同步,还是复杂的业务流水线处理,都需要一个可靠、高效的调度引擎来支撑。XXL-…...

汽车电子开发必备:3分钟搞定S19转HEX文件(附HexView详细操作截图)

汽车电子开发实战:S19与HEX文件高效转换指南 在汽车电子开发领域,文件格式转换是工程师日常工作中不可避免的环节。特别是当编译工具链生成的是S19格式文件,而目标平台或烧录工具仅支持HEX格式时,如何快速、准确地完成格式转换就成…...

利用Cesium后处理技术实现Shadertoy特效的跨平台移植

1. 为什么要把Shadertoy特效搬到Cesium? 第一次看到Shadertoy上那些酷炫的粒子效果和光影特效时,我就想:要是能把这些效果放到三维地球场景里该多酷啊!比如让极光在地球表面流动,或者给台风眼加上动态能量场效果。但实…...

五年跨境人掏心窝:多SKU铺货,我终于不用“爆肝”了!

大家好,我是跨境小彭。时间过得真快,一转眼,入坑跨境电商已经五年了。从最早一个人一台电脑在出租屋里倒腾,到现在有了自己的小团队,这中间的辛酸泪,估计只有咱们圈内人懂。最近,后台收到不少刚…...

Debian根文件系统定制:从零构建到实战优化

1. Debian根文件系统入门指南 第一次听说"根文件系统"这个概念时,我也是一头雾水。简单来说,它就像是你电脑的操作系统"骨架"——包含了启动、运行和管理系统所需的所有核心文件和目录。想象一下盖房子,根文件系统就是地…...

Twitter运营完整流程:从0到引流获客全流程拆解(2026)

在当前海外营销环境中,Twitter(X)已经成为获取流量和客户的重要渠道之一。但很多人在实际操作中都会遇到问题:不知道从哪里开始做了很久没有效果有流量但没有转化不清楚完整流程那么,Twitter运营到底该怎么做&#xff…...

深入解析javac编译错误:程序包XXX不存在的排查与修复指南

1. 程序包XXX不存在的本质原因 当你第一次在命令行用javac编译Java项目时,90%的新手都会遇到这个灵魂拷问:"程序包XXX不存在"到底是什么意思?这行红字背后其实藏着三个关键信息:类加载器找不到对应的.class文件&#xf…...

专业数据恢复师工具箱揭秘:UFS Explorer Pro的5个高级功能实战解析

专业数据恢复师工具箱揭秘:UFS Explorer Pro的5个高级功能实战解析 当一块硬盘的文件系统彻底崩溃,分区表不知所踪,或是RAID阵列的配置信息丢失时,普通数据恢复软件往往束手无策。这正是UFS Explorer Professional Recovery展现其…...

Electron实战:解决微信登录页二维码不显示的5个关键配置(附完整代码)

Electron微信登录页二维码显示问题的深度解决方案 微信登录已经成为现代桌面应用的标准功能之一,但Electron开发者在集成过程中常常遇到二维码无法显示的棘手问题。这并非简单的代码错误,而是微信安全机制与Electron特殊浏览器环境之间的微妙博弈。 1. 问…...

CherryStudio+Obsidian组合拳:打造自动更新的个人AI知识中枢

CherryStudioObsidian组合拳:打造自动更新的个人AI知识中枢 在信息爆炸的时代,科研人员和专业写作者面临的最大挑战不是获取知识,而是如何高效管理和持续更新个人知识体系。传统笔记工具虽然能帮助我们收集信息,但当知识量达到数千…...