浸入式学语言助手
July 18, 2025 · View on GitHub
一款基于"可理解输入"理论的浏览器扩展,帮助你在日常网页浏览中自然地学习语言。
简体中文 | English
🚀 快速安装
📥 官方商店安装(推荐)
Chrome/Edge 用户
Firefox 用户
💡 推荐:官方商店安装是最简单的方式 - 一键安装且自动更新!
✨ 核心理念
我坚信,语言学习的最佳途径是大量接触"可理解的"输入材料,即著名的 "i+1" 理论。这意味着内容应该略高于你当前的水平,既有挑战性,又不至于让你完全看不懂。本扩展旨在将整个互联网变成你的个性化语言学习教材,通过智能地将网页上的部分词语替换为你正在学习的目标语言词汇,让你在沉浸式的阅读中,不知不觉地提升词汇量和语感。
🎯 项目亮点: 集成了完整的发音学习生态系统和智能多语言翻译功能,包括自动语言检测、音标显示、AI词义解释、双TTS语音合成和交互式悬浮框,为用户提供从智能翻译到发音学习的一站式沉浸式体验。
📚 完整文档: 查看 架构与功能详解 了解技术架构、API接口、开发指南和故障排除。
🚀 功能特性
🎯 核心翻译引擎
- 智能语言检测: AI自动识别网页源语言,无需用户手动指定语言类型
- 智能文本处理: 使用大语言模型分析网页内容,智能选择适合用户水平的词汇进行翻译
- 精确替换控制: 可精确控制翻译比例(1%-100%),支持字符级精确计算
- 上下文感知: 考虑语境和用户水平,选择最合适的翻译词汇
- 多语言支持: 支持20+种语言的智能翻译(英语、日语、韩语、法语、德语、西班牙语、俄语、意大利语、葡萄牙语、荷兰语、瑞典语、挪威语、丹麦语、芬兰语、波兰语、捷克语、土耳其语、希腊语等)理论上依赖大模型能力
- 翻译位置控制: 新增翻译文本位置自定义功能,更灵活的显示方式
- 括号显示控制: 可选择是否显示翻译文本的括号,提供更清爽的阅读体验
- 懒加载翻译: 滚动到段落时才进行翻译,减少资源消耗和提高性能
🔊 发音学习生态系统 ⭐
- 交互式悬浮框: 鼠标悬停翻译词汇即可查看音标、AI词义和朗读功能,智能定位避免边界溢出
- 双层学习体验: 短语显示可交互的单词列表,点击单个单词查看详细信息,支持嵌套悬浮框
- 多TTS服务支持: 集成有道TTS(高质量)和Web Speech API(备用),支持英式/美式发音切换
- 智能音标获取: 自动获取Dictionary API音标数据,24小时TTL缓存优化性能
- AI词义解释: 实时调用AI生成中文词义解释,理解更准确,支持上下文语境分析
- 渐进式加载: 先显示基础信息,再异步加载详细内容,优化用户体验
- 音频缓存: 内存级TTS音频缓存,同一单词无需重复生成语音
- 快捷键支持: 新增发音弹出框快捷键设置,提升操作效率
🎨 丰富的视觉体验
- 7种翻译样式: 默认、微妙、粗体、斜体、下划线、高亮、学习模式(模糊效果)
- 学习模式: 翻译词汇初始模糊显示,鼠标悬停时清晰化,增强记忆效果
- 辉光动画: 新翻译词汇出现时的柔和提示效果,不干扰阅读体验
- 响应式设计: 自适应深色/浅色主题,智能悬浮框定位
- 悬浮工具球: 新增可配置的悬浮工具球,快速访问常用功能
- 外观设置: 支持自定义悬浮球透明度、位置等外观参数
⚙️ 高度可配置性
- 智能翻译模式: 用户只需选择目标语言,AI自动检测源语言并进行翻译
- 用户水平适配: 从初级到精通5个级别,AI智能调整词汇难度和选择策略
- 触发模式: 支持自动触发(页面加载时处理)和手动触发两种工作方式
- 原文显示控制: 可选择显示、隐藏或学习模式(模糊效果)显示被翻译的原文
- 段落长度控制: 自定义AI单次处理的最大文本长度
- 发音功能开关: 可独立控制发音悬浮框功能的启用状态
- 多API配置: 支持配置多个API服务,可灵活切换不同的翻译服务提供商
- 数据导入导出: 新增配置数据的导入导出功能,方便备份和迁移
- 界面语言: 支持5种界面语言(中文、英文、日文、韩文、西班牙文)
🔌 开放式API集成
- 兼容OpenAI API: 支持任何兼容 OpenAI 格式的AI服务(ChatGPT、Claude、豆包等国产大模型)
- Google Gemini支持: 新增Google Gemini API集成,提供更多AI服务选择
- 灵活配置: 自定义API Key、Endpoint、模型名称、Temperature参数
- 智能提示词: 根据翻译方向和用户水平动态生成最优提示词
- 错误处理: 完善的API错误处理和重试机制
- 多API支持: 支持配置多个API服务并灵活切换,提供更可靠的服务保障
- 思考模式: 支持AI思考过程输出,提升翻译质量
🖱️ 交互功能增强
- 右键菜单: 新增浏览器右键菜单功能,快速访问翻译相关操作
- 悬浮球功能: 可配置的悬浮工具球,提供快速翻译和设置访问
- 快捷键管理: 完善的快捷键设置和管理功能
- 网站管理: 黑名单和白名单功能,精确控制翻译行为
🚀 性能与优化
- 智能缓存: 翻译结果、音标数据、TTS音频多级缓存策略
- 增量处理: 只处理新增内容,避免重复翻译
- DOM安全: 使用Range API确保DOM结构完整性
- 内存管理: 及时清理监听器,优化内存使用
- 懒加载优化: 滚动时按需翻译,减少初始加载时间
💻 现代技术架构
- 框架: WXT - 现代WebExtension开发框架
- 前端: Vue 3 + TypeScript + Vite
- UI库: Tailwind CSS + Lucide Icons + Reka UI
- 构建: ESLint + Prettier + TypeScript编译
- API集成: OpenAI兼容接口 + Google Gemini + Dictionary API + 有道TTS
- 跨浏览器兼容: 支持Chrome、Edge、Firefox,部分支持Safari
- 国际化: Vue I18n支持多语言界面
🌐 浏览器兼容性
本扩展基于 Web Extension API 和 WXT 构建,支持以下浏览器:
| 浏览器 | 支持状态 | 特殊说明 |
|---|---|---|
| Chrome | ✅ 完全支持 | 推荐环境,所有功能可用 |
| Edge | ✅ 完全支持 | 基于Chromium,完整兼容 |
| Firefox | ✅ 支持 | 需配置addon ID,详见Firefox安装指南 |
| Safari | ⚠️ 部分支持 | 需要额外配置,自行查询 |
⚡ 性能特性
🚀 智能缓存系统
- 翻译结果: 基于内容和设置的智能缓存,避免重复API调用
- 音标数据: 24小时TTL本地缓存,提升响应速度
- TTS音频: 内存级缓存,同一单词无需重复生成语音
🔄 增量处理机制
- DOM监听: 只处理新增内容,避免重复翻译
- 防抖优化: 动态内容变化时的智能延迟处理
- Range API: 精确DOM操作,保持页面结构完整性
- 懒加载: 滚动时按需翻译,优化性能
📸 功能展示
🎬 动态演示
🎯 完整演示: 从智能翻译到发音学习的一站式沉浸式体验
🎨 主题适配展示
🌗 主题适配: 深色/浅色主题智能切换,现代化视觉体验
👍 设置页支持多种配置
🌍 多语言学习场景
🧠 智能多语言: 支持20+种语言的AI自动检测和翻译,涵盖中文、英语、日语、韩语等主流学习语言
🛠️ 开发者安装
🔧 从源码构建(开发者)
如果你想参与开发或需要从源码构建:
1. 先决条件
2. 安装
-
克隆仓库:
git clone https://github.com/xiao-zaiyi/illa-helper.git cd illa-helper -
安装依赖:
npm install
提示: 如果你只想使用这个扩展而不参与开发,请直接前往 Releases 页面下载最新版本的打包文件。
3. 配置
项目通过 .env 文件管理本地开发环境的配置。
-
创建
.env文件: 复制.env.example文件来创建你自己的本地配置文件。cp .env.example .env -
修改配置: 打开新建的
.env文件,至少你需要提供一个有效的 API Key 才能让翻译功能正常工作。VITE_WXT_DEFAULT_API_KEY="sk-your-real-api-key" # 你也可以在这里覆盖其他的默认设置 VITE_WXT_DEFAULT_API_ENDPOINT="https://xxxxx/api/v1/chat/completions" VITE_WXT_DEFAULT_MODEL="gpt-4" VITE_WXT_DEFAULT_TEMPERATURE="0.2"注意:
.env文件已被添加到.gitignore中,所以你的密钥不会被意外提交。
4. 构建扩展
根据目标浏览器执行相应的构建命令:
Chrome/Edge构建
npm run build
npm run zip
Firefox构建
npm run build:firefox
npm run zip:firefox
5. 加载扩展
Chrome/Edge安装
- 打开浏览器(Chrome、Edge等)
- 进入扩展管理页面(
chrome://extensions或edge://extensions) - 打开 "开发者模式"
- 点击 "加载已解压的扩展程序"
- 选择项目根目录下的
.output/chrome-mv3文件夹 - 完成!现在你应该能在浏览器工具栏看到扩展的图标了
Firefox安装指南
Firefox由于安全限制,需要特殊的安装步骤:
正式版目前不能通过此方法安装,只能通过商店进行安装。
方法一:临时安装(推荐开发调试)
- 在Firefox地址栏输入
about:debugging#/runtime/this-firefox - 点击 "临时加载附加组件..."
- 选择
.output/firefox-mv2/manifest.json文件 - 扩展将以临时方式加载,浏览器重启后需要重新加载
方法二:修改安全配置(永久安装)
- 在Firefox地址栏输入
about:config - 搜索
xpinstall.signatures.required - 双击将值改为
false - 现在可以通过
about:addons安装未签名的扩展
Firefox Storage API配置说明
Firefox中的storage API需要明确的addon ID才能正常工作。本项目已在 wxt.config.ts 中配置了Firefox特定设置:
browser_specific_settings: {
gecko: {
id: 'illa-helper@1932794922@qq.com',
strict_min_version: '88.0'
}
}
这确保了在Firefox中可以正常使用存储功能保存用户设置。
🔧 核心技术栈
- 框架: WXT - 现代WebExtension开发框架
- 前端: Vue 3 + TypeScript + Vite
- UI库: Tailwind CSS + Lucide Icons
- 构建: ESLint + Prettier + TypeScript编译
- API集成: OpenAI兼容接口 + Google Gemini + Dictionary API + 有道TTS
- 架构模式: Provider模式 + 模块化设计 + 事件驱动
- 发音系统: 工厂模式 + 多TTS服务 + 智能缓存
- 存储管理: 配置版本控制 + 跨浏览器兼容
- 国际化: Vue I18n支持多语言界面
📖 查看详细文档: 架构与功能详解 - 包含完整的技术架构、API参考和开发指南
❓ 常见问题
为什么我需要提供API密钥?
本扩展使用AI技术进行智能文本翻译,这需要调用API服务。您可以使用 OpenAI 的API密钥,或任何兼容 OpenAI API格式的第三方服务,包括新支持的Google Gemini API。
发音功能如何工作?
发音系统是我们的核心特色功能,提供完整的学习体验:
- 音标显示: 自动获取Dictionary API音标数据
- AI词义: 实时调用AI获取中文释义解释
- 双TTS支持: 有道TTS(高质量)+ Web Speech API(备用)
- 交互悬浮框: 鼠标悬停查看,支持英美发音切换
- 短语学习: 短语中每个单词都可独立查看和朗读
智能翻译模式如何使用?
智能翻译是我们的新功能,使用简单:
- 选择翻译模式: 在设置中选择"🧠 智能多语言模式"
- 选择目标语言: 从20+种支持语言中选择你想学习的语言
- 开始浏览: AI会自动检测网页语言并翻译到你的目标语言
- 无需额外配置: 系统会自动处理不同语言的网页内容
扩展会收集我的浏览数据吗?
不会。本扩展在本地处理所有网页内容,只将需要翻译的文本片段发送到配置的API服务。发音功能的音标和词义数据也会本地缓存,保护您的隐私。
我可以控制翻译比例吗?
可以。扩展提供了精确的翻译控制:
- 语言水平: 5个级别从初级到精通,AI智能调整词汇难度
- 替换比例: 1%-100%精确控制,支持按字符数计算
- 原文显示: 可选择显示、隐藏或学习模式(模糊效果)
- 智能适配: 在智能模式下,系统会根据检测到的语言自动优化翻译策略
Safari浏览器如何安装?
Safari需要额外的步骤将Web扩展打包为Safari扩展。请参考Apple开发者文档。
Firefox相关问题解决 🚨
根据 Firefox 中的附加组件签名,唯有 延长支持版(ESR)、开发者版和 Nightly 版才会读取
xpinstall.signatures.required为false的配置;普通版本即使设置false仍只能通过临时安装的方式。
"获取用户设置失败: Error: The storage API will not work with a temporary addon ID"
这是Firefox的已知限制。解决方案:
- 使用最新版本: 确保使用最新的构建版本,已包含Firefox特定配置
- 使用Firefox专用构建: 运行
npm run build:firefox && npm run zip:firefox - 临时安装: 通过
about:debugging页面安装,而不是直接安装.xpi文件
"扩展此组件无法安装,因为它未通过验证"
- 方法一:通过在地址栏输入
about:debugging#/runtime/this-firefox选择临时加载附加组件...可以从文件安装Firefox扩展 - 方法二:地址栏输入
about:config搜索xpinstall.signatures.required设置项,双击改为false
API相关问题
"API配置错误"通知
检查以下配置:
- API Key格式是否正确(通常以
sk-开头) - API Endpoint URL是否有效
- 模型名称是否支持
- 网络连接是否正常
翻译质量不理想
可以尝试:
- 调整用户水平设置
- 修改翻译比例
- 更换更强大的AI模型
- 调整Temperature参数(建议0.1-0.3)
🛠️ 故障排除
常见问题诊断
1. 扩展加载失败
- 检查Node.js版本(需要18+)
- 确保依赖安装完整:
npm install - 查看构建日志是否有错误
2. 翻译功能不工作
- 验证API配置是否正确
- 检查网络连接
- 查看开发者控制台错误信息
3. 发音功能异常
- 确保浏览器支持Web Speech API
- 检查有道TTS服务状态
- 验证Dictionary API可访问性
4. 设置无法保存
- Firefox用户确认使用正确的安装方式
- 检查扩展权限设置
- 清除浏览器缓存后重试
5. 内容脚本功能异常
- 检查ContentManager服务是否正常初始化
- 查看控制台是否有服务加载错误
- 验证配置服务和处理服务状态
- 确认网站不在黑名单中
🤝 贡献指南
我们非常欢迎各种形式的贡献!无论是提交 Bug、提出新功能建议,还是直接贡献代码。
如何贡献
-
提交问题
- 使用 GitHub Issues 报告 bug 或提出功能建议
- 清晰描述问题或建议的详细内容
- 如果是 bug,请提供复现步骤和环境信息
-
贡献代码
- Fork 本仓库
- 创建一个新的分支 (
git checkout -b feature/your-amazing-feature) - 编写并测试您的代码
- 确保代码遵循项目的编码规范
- 提交您的代码更改 (
git commit -m 'Add some amazing feature') - 将您的分支推送到远程仓库 (
git push origin feature/your-amazing-feature) - 创建一个 Pull Request
-
改进文档
- 文档改进对项目同样重要
- 可以修正错别字、完善解释或添加示例
开发指南
- 架构原则: 遵循Provider模式和模块化设计,特别是发音系统的工厂模式
- 代码规范: TypeScript严格模式,ESLint + Prettier格式化,完整类型定义
- 测试要求: 确保新功能在多种浏览器和网站上正常工作,特别是多语言环境
- 性能考虑: 注意DOM操作效率、内存管理和多语言缓存策略
- API兼容: 保持与现有API接口的向后兼容性,支持配置版本迁移
- 多语言支持: 新增语言时需要在languageManager.ts注册并测试翻译效果
- 发音功能: 扩展TTS服务时需要实现ITTSProvider接口并注册到工厂
- 浏览器兼容性: 新功能需要在Chrome、Edge、Firefox中测试
- 新功能开发: 新增功能时需要考虑国际化支持和用户配置管理
📖 详细开发指南: 查看 架构与功能详解 获取完整的开发环境配置、代码结构说明和最佳实践。
🔗 相关链接
- 项目主页: GitHub Repository
- 问题反馈: GitHub Issues
- 版本发布: GitHub Releases
- 技术文档: 架构与功能详解
- WXT框架: WXT.dev
📧 联系我们
- 作者: Xiao-zaiyi
- GitHub: @xiao-zaiyi
- 项目讨论: 通过GitHub Issues进行技术讨论
📜 版权许可
本项目基于 MIT License 开源。您可以自由使用、修改和分发此代码,包括用于商业目的。
🌟 Star History 
⭐ 如果这个项目对您有帮助,请给我们一个Star!
🔄 欢迎Fork并贡献您的改进!