Internet Archive BookReader v5.0.0-92 版本发布:搜索插件架构重构解析
Internet Archive BookReader 是一个开源的在线电子书阅读器解决方案,它提供了丰富的功能来展示和阅读数字化书籍。该项目由 Internet Archive 维护,广泛应用于各类数字图书馆和电子书阅读平台。
本次发布的 v5.0.0-92 版本主要对搜索功能进行了重大重构,将原有的搜索实现迁移到了新的 BookReaderPlugin 系统。这一变化不仅带来了架构上的改进,也为开发者提供了更灵活的自定义选项。
搜索插件架构重构
本次重构的核心是将搜索功能从核心代码中解耦,使其成为一个独立的插件。这种模块化的设计带来了几个显著优势:
- 代码组织更清晰:搜索相关逻辑现在集中在 SearchPlugin 类中,不再分散在核心代码各处
- 维护性提升:插件系统提供了标准化的接口,便于未来扩展和维护
- 自定义能力增强:开发者现在可以通过配置更精细地控制搜索行为
配置变更详解
重构后,搜索相关的配置选项都移动到了 options.plugins.search 命名空间下。以下是主要变更点:
搜索标记配置
原先的 searchInsidePreTag 和 searchInsidePostTag 现在简化为 preTag 和 postTag,位于插件配置中。这些标记用于高亮显示搜索结果。
搜索端点URL重构
searchInsideUrl 现在支持更强大的字符串模板功能(StringWithVars),开发者可以动态构建搜索URL。新特性包括:
- 支持从根选项中引用变量(如 {{server}})
- 自动URL编码功能({{query|urlencode}})
- 可以访问 preTag和postTag配置
- 不再局限于Internet Archive特定的逻辑
初始搜索词配置
initialSearchTerm 现在也移到了插件配置中,保持配置结构的一致性。
废弃项说明
searchInsideProtocol 配置项已被弃用,推荐使用新的URL模板变量功能替代。
API变更与兼容性
本次重构对API进行了整理,大部分搜索相关的方法和属性现在都位于 SearchPlugin 实例中。值得注意的是:
- br.search仍然保留作为快捷访问方式
- 原有的搜索相关属性和方法(如 searchResults,searchXHR等)都已迁移到插件内部
- 搜索高亮相关方法(updateSearchHilites,removeSearchResults等)也移到了插件中
这种变更虽然带来了一些破坏性变化,但为未来的功能扩展奠定了更好的基础。
升级建议
对于正在使用BookReader的项目,升级到本版本时需要注意:
- 检查所有搜索相关的配置,按照新的结构进行调整
- 如果直接调用了搜索相关API,需要更新调用路径
- 利用新的URL模板功能简化搜索端点的配置
- 测试搜索高亮功能,确保 preTag和postTag配置正确
总结
v5.0.0-92 版本通过对搜索功能的插件化重构,显著提升了BookReader的架构质量。虽然带来了一些破坏性变更,但这些改进为开发者提供了更强大、更灵活的自定义能力,同时也为未来的功能扩展铺平了道路。建议所有使用搜索功能的项目规划升级,以利用这些改进带来的好处。
 PaddleOCR-VLPaddleOCR-VL 是一款顶尖且资源高效的文档解析专用模型。其核心组件为 PaddleOCR-VL-0.9B,这是一款精简却功能强大的视觉语言模型(VLM)。该模型融合了 NaViT 风格的动态分辨率视觉编码器与 ERNIE-4.5-0.3B 语言模型,可实现精准的元素识别。Python00 PaddleOCR-VLPaddleOCR-VL 是一款顶尖且资源高效的文档解析专用模型。其核心组件为 PaddleOCR-VL-0.9B,这是一款精简却功能强大的视觉语言模型(VLM)。该模型融合了 NaViT 风格的动态分辨率视觉编码器与 ERNIE-4.5-0.3B 语言模型,可实现精准的元素识别。Python00
- DDeepSeek-OCRDeepSeek-OCR是一款以大语言模型为核心的开源工具,从LLM视角出发,探索视觉文本压缩的极限。Python00
 MiniCPM-V-4_5MiniCPM-V 4.5 是 MiniCPM-V 系列中最新且功能最强的模型。该模型基于 Qwen3-8B 和 SigLIP2-400M 构建,总参数量为 80 亿。与之前的 MiniCPM-V 和 MiniCPM-o 模型相比,它在性能上有显著提升,并引入了新的实用功能Python00 MiniCPM-V-4_5MiniCPM-V 4.5 是 MiniCPM-V 系列中最新且功能最强的模型。该模型基于 Qwen3-8B 和 SigLIP2-400M 构建,总参数量为 80 亿。与之前的 MiniCPM-V 和 MiniCPM-o 模型相比,它在性能上有显著提升,并引入了新的实用功能Python00
 HunyuanWorld-Mirror混元3D世界重建模型,支持多模态先验注入和多任务统一输出Python00 HunyuanWorld-Mirror混元3D世界重建模型,支持多模态先验注入和多任务统一输出Python00
 AI内容魔方AI内容专区,汇集全球AI开源项目,集结模块、可组合的内容,致力于分享、交流。03 AI内容魔方AI内容专区,汇集全球AI开源项目,集结模块、可组合的内容,致力于分享、交流。03
 Spark-Scilit-X1-13B科大讯飞Spark Scilit-X1-13B基于最新一代科大讯飞基础模型,并针对源自科学文献的多项核心任务进行了训练。作为一款专为学术研究场景打造的大型语言模型,它在论文辅助阅读、学术翻译、英语润色和评论生成等方面均表现出色,旨在为研究人员、教师和学生提供高效、精准的智能辅助。Python00 Spark-Scilit-X1-13B科大讯飞Spark Scilit-X1-13B基于最新一代科大讯飞基础模型,并针对源自科学文献的多项核心任务进行了训练。作为一款专为学术研究场景打造的大型语言模型,它在论文辅助阅读、学术翻译、英语润色和评论生成等方面均表现出色,旨在为研究人员、教师和学生提供高效、精准的智能辅助。Python00
 GOT-OCR-2.0-hf阶跃星辰StepFun推出的GOT-OCR-2.0-hf是一款强大的多语言OCR开源模型,支持从普通文档到复杂场景的文字识别。它能精准处理表格、图表、数学公式、几何图形甚至乐谱等特殊内容,输出结果可通过第三方工具渲染成多种格式。模型支持1024×1024高分辨率输入,具备多页批量处理、动态分块识别和交互式区域选择等创新功能,用户可通过坐标或颜色指定识别区域。基于Apache 2.0协议开源,提供Hugging Face演示和完整代码,适用于学术研究到工业应用的广泛场景,为OCR领域带来突破性解决方案。00 GOT-OCR-2.0-hf阶跃星辰StepFun推出的GOT-OCR-2.0-hf是一款强大的多语言OCR开源模型,支持从普通文档到复杂场景的文字识别。它能精准处理表格、图表、数学公式、几何图形甚至乐谱等特殊内容,输出结果可通过第三方工具渲染成多种格式。模型支持1024×1024高分辨率输入,具备多页批量处理、动态分块识别和交互式区域选择等创新功能,用户可通过坐标或颜色指定识别区域。基于Apache 2.0协议开源,提供Hugging Face演示和完整代码,适用于学术研究到工业应用的广泛场景,为OCR领域带来突破性解决方案。00
- HHowToCook程序员在家做饭方法指南。Programmer's guide about how to cook at home (Chinese only).Dockerfile014
 Spark-Chemistry-X1-13B科大讯飞星火化学-X1-13B (iFLYTEK Spark Chemistry-X1-13B) 是一款专为化学领域优化的大语言模型。它由星火-X1 (Spark-X1) 基础模型微调而来,在化学知识问答、分子性质预测、化学名称转换和科学推理方面展现出强大的能力,同时保持了强大的通用语言理解与生成能力。Python00 Spark-Chemistry-X1-13B科大讯飞星火化学-X1-13B (iFLYTEK Spark Chemistry-X1-13B) 是一款专为化学领域优化的大语言模型。它由星火-X1 (Spark-X1) 基础模型微调而来,在化学知识问答、分子性质预测、化学名称转换和科学推理方面展现出强大的能力,同时保持了强大的通用语言理解与生成能力。Python00
- PpathwayPathway is an open framework for high-throughput and low-latency real-time data processing.Python00
最新内容推荐
项目优选
 docs
docs kernel
kernel flutter_flutter
flutter_flutter ops-math
ops-math pytorch
pytorch cangjie_tools
cangjie_tools ohos_react_native
ohos_react_native RuoYi-Vue3
RuoYi-Vue3 torchair
torchair cangjie_compiler
cangjie_compiler