kkFileView基于pdf.js实现多词高亮

参考文档:

1.文件文档在线预览转换解决方案和应用

2.kkfileview预览pdf格式文件,实现多关键词高亮和定位_kkfileview+高亮方案-CSDN博客

3.PDF.js实现搜索多个不同的关键词高亮显示效果

最终效果:

需求描述:

预览文件时,在文档中高亮显示搜索的文字,并实现分词、多词搜索

如:需要搜索"项目",文件中需要高亮所有的 "项" 和 "目"

解决代码:

  1. kkFileView属于开源,我们是基于kkFileView的代码修改实现。

需要的可以kkFileView---gitee地址中下载。

  1. 根据参考文档1和2,基本可以实现高亮,但不能分开高亮,"项" 和 "目" 。

  2. 根据参考文档3,实现分开高亮。

在文件 resources/static/pdfjs/web/viewer.js 中添加代码:

  • _initializeViewerComponents 方法中:
javascript 复制代码
    // 添加代码
    // 自定义搜索关键词----------------------------------------
    this.searchKeywords = keyword => {
      if (typeof PDFViewerApplication !== 'undefined') {
        PDFViewerApplication.eventBus.dispatch('find', {
          query: keyword,
          caseSensitive: false,
          highlightAll: true,
          findPrevious: true
        });
      }
    }
  • setInitialView 方法中:
javascript 复制代码
    // 添加代码    
    // 高亮显示N个关键词----------------------------------------
    // 获取关键词数组
    var keywords = new URL(decodeURIComponent(location)).searchParams.get('keyword');
    if (keywords && keywords !== 'undefined') {
      this.searchKeywords(keywords.split('|'));
      setTimeout(() => {
        // 让高亮效果统一,避免最后一个聚焦的样式不同
        document.querySelector(`.highlight.selected`).classList.remove('selected');
      }, 1000);
    }
  1. new URL(decodeURIComponent(location)).searchParams.get('keyword') 中的 'keyword'对应效果图中地址后拼接的 **&keyword=**搜索的文字。
  2. this.searchKeywords(keywords.split('|')):根据 | 切割字符串为数组。后面优化了一下为this.searchKeywords(keywords.split('')),自动每个字都为搜索关键字。即最终效果图所示。

总结:

这篇主要记录一下需求,所有成效均为借鉴参考文档。

后续会融入到项目中.....

相关推荐
Eiceblue6 小时前
Python读取PDF:文本、图片与文档属性
数据库·python·pdf
AAA_自动化工程师9 小时前
TIA博途中的程序导出为PDF格式的具体方法示例
pdf·tia博途·程序导出·pdf格式·具体方法
行云流水剑9 小时前
【学习记录】如何使用 Python 提取 PDF 文件中的内容
python·学习·pdf
IDRSolutions_CN10 小时前
PDF 转 HTML5 —— HTML5 填充图形不支持 Even-Odd 奇偶规则?(第二部分)
java·经验分享·pdf·软件工程·团队开发
upp11 小时前
【bug】Error: /undefinedfilename in (/tmp/ocrmypdf.io.9xfn1e3b/origin.pdf)
ubuntu·pdf·bug·ghostscript
沉到海底去吧Go15 小时前
【工具教程】多个条形码识别用条码内容对图片重命名,批量PDF条形码识别后用条码内容批量改名,使用教程及注意事项
pdf
摸鱼仙人~16 小时前
PDF图片和表格等信息提取开源项目
pdf
空中湖1 天前
文档极速转换器 - 免费批量Word转PDF工具
pdf·word
沉到海底去吧Go1 天前
【工具教程】PDF电子发票提取明细导出Excel表格,OFD电子发票行程单提取保存表格,具体操作流程
pdf·excel
诸葛大钢铁2 天前
PDF转PPT转换方法总结
pdf·powerpoint