vue web-highlighter 划词高亮功能实现及遇到的问题(线上图书)

 gitcode web-highlighter 快速通道

gitHub web-highlighter 快速通道

1、下载插件

npm i web-highlighter

2、引入插件

import Highlighter from "web-highlighter";

3、初始化插件

mounted(){this.highlighter = new Highlighter({$root: document.getElementById("preview_text"), // 使用位置的根元素exceptSelectors: null, // 如果元素与选择器匹配,则不会突出显示wrapTag: "span",style: {className: ["double-line-highlight", "yellowline-color-highlight"],},verbose: false, // 它需要输出(打印)一些警告和错误消息吗exceptSelectors: [], // 要跳过的元素   'h1', '.title'});
}

4、使用

 <div id="preview_text" class="content" v-html="bookInfo" @mouseup.navtive="mouseup_highlight"></div>
.exam_hig {background-color: red;
}
// 通过 window.getSelection() 获取用户选中元素
mouseup_highlight(event){var that = this;that.active_event = event.target; // 选中标签that.sel = window.getSelection(); // 选中文本that.range = that.sel.getRangeAt(0) // 获取范围对象
}// 保存接口
postHig(){// 也可以在保存之前修改高亮器的选项。参数结构与构造函数相同,可以只传递部分选项。this.highlighter.setOption({style: {className: ['exam_hig'],},});// highlighter.fromRange(range) 创建高亮区域时由web-highlighter生成的一种特殊对象。为了在后台(数据库)中持久化表示DOM节点,需要找到一种数据结构,这就是web-highlighter中的HighlightSource。this.HighlightSource = await this.highlighter.fromRange(this.range);this.HighlightSource.claName = 'exam_hig'  // 这是因项目需要不同高亮效果我自己自定义的高亮类名var formdata = new FormData();formdata.append("highlightSource", JSON.stringify(this.HighlightSource));// 将高亮后的信息保存到数据库const { data, code, msg, count } = await this.$https.postHighlightSource()
}

HighlightSource 返回的属性的意义:

  • start:关于起始元素的元信息
  • end:关于结束元素的元信息
  • text:文本内容
  • id:唯一标识符

注意:修改、删除都需要用到 id

5、页面回显

// 获取高亮列表
getHigList(){let formData = new FormData();const { data, code, msg } = await this.$https.getHighlightSourceList(formData);if(code == 200){this.hig_list = datathis.hig_list.forEach(item=>{var info_block = JSON.parse(item.higObj); // 返回的高亮信息var location_dom = this.highlighter.getDoms(info_block.id) // 获取位置if (location_dom.length == 0) {this.highlighter.setOption({style: {className: info_block.claName,},});this.HighlightSource = await this.highlighter.fromStore(info_block.startMeta,info_block.endMeta,info_block.text,info_block.id);)}
}

 注意:返回的列表需要排序!!!不然可能导致高亮位置错误!!!

6、修改

// id 为  HighlightSource 对象中的高亮唯一标识
editHig(id){// 直接切换类名this.highlighter.removeClass('redClassName', id);this.highlighter.addClass('greenClassName', id);
}

7、删除

// id 为  HighlightSource 对象中的高亮唯一标识
delHig(id){this.highlighter.remove(id);
}

8、销毁

beforeDestroy(){// 当你不再需要使用高亮功能时,需要先使用该方法来移除一些事件监听,回收一些资源。this.highlighter.dispose();
}

遇到的问题:

1、回显高亮位置错误

        可能是列表没有排序导致的(反正我就是)因为这个插件是一个序列化与反序列化的过程

2、HighlightSource  返回为 null

        可能是没有正确获取到标签导致的,需要先完成页面的DOM加载后再获取。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/63808.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Mave下载、安装以及idea(2024)进行配置

目录 Maven简介 Maven下载 配置环境变量 配置本地仓库 在idea环境配置Maven 使用Maven创建工程 创建一个普通的java工程 创建一个Web项目 Maven简介 Maven是一个跨平台的项目管理工具&#xff0c;也是Apache组织中的一个成功的开源项目。它主要服务于基于Java的项目构…

ios 开发配置蓝牙

如果使用了蓝牙功能, 又没有配置, 会出现以下错误: This app has crashed because it attempted to access privacy-sensitive data without a usage description. The apps Info.plist must contain an NSBluetoothAlwaysUsageDescription key with a string value explaini…

Linux 简单命令总结

1. 简单命令 1.1. ls 列出该目录下的所有子目录与文件&#xff0c;后面还可以跟上一些选项 常用选项&#xff1a; ・-a 列出目录下的所有文件&#xff0c;包括以。开头的隐含文件。 ・-d 将目录象文件一样显示&#xff0c;而不是显示其下的文件。如&#xff1a;ls -d 指定目…

【反无人机目标检测与跟踪】DUT Anti-UAV数据集介绍

DUT Anti-UAV数据集是IEEE TITS 2023上大连理工大学团队提出的Vision-based Anti-UAV Detection and Tracking论文中提出的一个可见光反无人机检测与跟踪数据集。 因为反无人机目标检测与跟踪的数据集都比较少&#xff0c;因此这个数据集也非常宝贵。 这个数据集的链接如下 数…

【JAVA】Java项目实战—Java 数据库应用项目:学生信息管理系统

本项目将实现一个简单的学生信息管理系统&#xff0c;功能包括学生信息的录入、查询、修改和删除。通过本项目&#xff0c;读者将深入理解Java与数据库交互的基本原理&#xff0c;掌握JDBC&#xff08;Java Database Connectivity&#xff09;技术&#xff0c;以及如何构建一个…

【热力学与工程流体力学】流体静力学实验,雷诺实验,沿程阻力实验,丘里流量计流量系数测定,局部阻力系数的测定,稳态平板法测定材料的导热系数λ

关注作者了解更多 我的其他CSDN专栏 过程控制系统 工程测试技术 虚拟仪器技术 可编程控制器 工业现场总线 数字图像处理 智能控制 传感器技术 嵌入式系统 复变函数与积分变换 单片机原理 线性代数 大学物理 热工与工程流体力学 数字信号处理 光电融合集成电路…

Android UI:ViewTree:源码分析:事件处理:显示事件

文章目录 概述测量:measure和onMeasure​​​​​​​ View.MeasureSpecViewViewGroupLinearLayoutRelativeLayout布局:layout和onLayout ViewViewGroupLinearLayoutRelativeLayout绘制:dispatchDraw、draw和onDraw ViewViewGroupLinearLayoutRelativeLayout总结概述 显示事…

Angular由一个bug说起之十二:网页页面持续占用CPU过高

随着网络日益发达&#xff0c;网页的内容也更加丰富&#xff0c;形式也更加多样化。而随之而来的性能问题也不容小觑。这篇文章我会根据我在实践中遇到的一个问题来总结&#xff0c;我在面对性能问题的一些解决步骤&#xff0c;希望能对大家有所启发。 查找问题原因 我接触的…

游戏引擎学习第44天

仓库: https://gitee.com/mrxiao_com/2d_game 向量数学的重要性 矢量数学非常重要&#xff0c;因为 它在某种程度上类似于将C和C视为高于汇编语言的语言&#xff0c;从而使得我们能够以略高的层次思考问题&#xff0c;同时保留大部分性能好处和直接访问的类型。这种思维方式就…

Android中bindService和startService启动服务有何区别

Android中bindService和startService启动服务有何区别 bindService 和 startService 是 Android 中两种用于与 Service 交互的方式&#xff0c;它们的区别主要在于 生命周期管理 和 使用场景。以下是详细对比&#xff1a; 1. bindService方式 bindService 是一种绑定方式&am…

通俗易懂的 Nginx 反向代理 配置

通俗易懂的 Nginx 反向代理 配置 首先 root 与 alias 的区别 root 是直接拼接 root location location /i/ {root /data/w3; }当请求 /i/top.gif &#xff0c;/data/w3/i/top.gif 会被返回。 alias 是用 alias 替换 location location /i/ {alias /data/w3/images/; }当请…

【NLP高频面题 - 词嵌入篇】为什么说Word2vec的词向量是静态的?

【NLP高频面题 - 词嵌入篇】为什么说Word2vec的词向量是静态的&#xff1f; 重要性&#xff1a;★★ NLP Github 项目&#xff1a; NLP 项目实践&#xff1a;fasterai/nlp-project-practice 介绍&#xff1a;该仓库围绕着 NLP 任务模型的设计、训练、优化、部署和应用&#xf…

PyTorch基本使用-张量的基本运算及函数计算

文章目录 1. 张量数值计算1. 1 张量基本运算1.2 点乘运算1.3 矩阵运算 2. 张量运算函数 1. 张量数值计算 1. 1 张量基本运算 加减乘除取负号&#xff1a; add、sub、mul、div、neg add_ 、sub_、 mul_ 、div_、 neg_ (其中带下划线的版本会修改原数据) data torch.randin…

如何使用 Python 实现 UDP 通信?

1. UDP通信基础 UDP&#xff08;用户数据报协议&#xff09;是一种无连接的传输层协议&#xff0c;它提供了一种不可靠的数据传输服务&#xff0c;但具有较低的延迟和较小的开销。在Python中&#xff0c;可以使用socket模块来实现UDP通信。 2. 实现UDP服务端 import socketd…

【保姆级】Mac如何安装+切换Java环境

本文从如何下载不同版本的JDK,到如何丝滑的切换JDK,以及常见坑坑的处理方法,应有尽有,各位看官走过路过不要错过~~~ 下载⏬ 首先上官网: https://www.oracle.com/ 打不开的话可以使用下面👇这个中文的 https://www.oracle.com/cn/java/technologies/downloads/a…

Android -- WebView之loadData加载html字符串显示网页

目录 前言1. loadUrl 加载网页地址2. loadData 加载Html字符来显示网页3. loadDataWithBaseURL4. 总结 前言 最近在给一个老项目做64位so文件的适配&#xff0c;当应用发布到应用市场上后&#xff0c;用户反馈64位手机上的网页加载不出内容&#xff0c;但32位的手机上是正常…

WebSocket解读

WebSocket是一种网络通信协议&#xff0c;它允许在单个TCP连接上进行全双工通信&#xff0c;即服务器和客户端可以同时发送和接收数据。这种协议非常适合需要实时数据交换的应用场景&#xff0c;如在线聊天、实时数据更新、协同办公等。 WebSocket的工作原理 握手阶段&#x…

Docker在Ubuntu和CentOS系统下的安装

目录 1. 各版本平台支持情况2. 在Ubuntu系统下安装docker3. 常见报错4. Docker的镜像源修改5. Docker目录修改6. 在CentOS系统下安装docker 1. 各版本平台支持情况 &#xff08;1&#xff09;平台支持情况如下&#xff1a; Server 版本 桌面版本 2. 在Ubuntu系统下安装docker…

Ansible-Playbook基础学习

一.Ansible Playbook基本介绍 1.Playbook 介绍 Ansible Playbook 是 Ansible 的核心组件之一&#xff0c;它是一个用于配置管理、应用部署和任务自动化的文本文件&#xff0c;使用 YML格式编写。YML 的语法简洁明了&#xff0c;易于阅读和编写&#xff0c;使得用户可以方便地…

基于PHP课堂签到系统的设计与实现

摘 要 随着教育业的迅速发展和学生人数的不断增加&#xff0c;导致在班级登记制度中传统的“点到”方式不能适应学校的实际需要。从而需要设计一个好的课堂签到系统将会对课堂签到管理工作带来事半功倍的效果。文章着重介绍了基于实践应用的班级签到系统的开发流程&#xff0c…