视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
如何为选择的文本添加一个类名(js+css实现)
2020-11-27 19:32:20 责编:小采
文档

这样的话咱们先来学习DOM2和DOM3的几个概念

1、window.getSelection()

getSelection() 方法,可以确定实际选择的文本。
这个方法是 window 对象和 document 对象的属性,调用它会返回一个表示当前选择文本的 Selection对象。
每个 Selection 对象都有下列属性。

anchorNode :选区起点所在的节点。

anchorOffset :在到达选区起点位置之前跳过的 anchorNode 中的字符数量。

focusNode :选区终点所在的节点。

focusOffset : focusNode 中包含在选区之内的字符数量。

isCollapsed :布尔值,表示选区的起点和终点是否重合。

rangeCount :选区中包含的 DOM 范围的数量

addRange(range) :将指定的 DOM 范围添加到选区中。

collapse(node, offset) :将选区折叠到指定节点中的相应的文本偏移位置。

collapseToEnd() :将选区折叠到终点位置。

collapseToStart() :将选区折叠到起点位置。

containsNode(node) :确定指定的节点是否包含在选区中。

deleteFromDocument() :从文档中删除选区中的文本,与 document.execCommand("delete",false, null) 命令的结果相同。

extend(node, offset) :通过将 focusNode 和 focusOffset 移动到指定的值来扩展选区。

getRangeAt(index) :返回索引对应的选区中的 DOM 范围。

removeAllRanges() :从选区中移除所有 DOM 范围。实际上,这样会移除选区,因为选区中至少要有一个范围。

reomveRange(range) :从选区中移除指定的 DOM 范围。

selectAllChildren(node) :清除选区并选择指定节点的所有子节点。

toString() :返回选区所包含的文本内容。

by-《javascript高级程序设计》

咱们需要用到的就是getRangeAt()这个属性,这个属性返回索引对应的选区中的 DOM 范围,是一个Range对象这样就记住了获取文档片段的位置。
console一下看看这个属性所在位置

2. Range.extractContents()

extractContents(),会从文档中移除范围选区,并返回范围的文档片段,这样就获得了想要的文档片段。

3. Range.insertNode(

insertNode(),是在Range的起始位置插入节点的方法。详细属性可以自行参考MDN或者高程

console一下看看上两个属性所在位置

接下来就上代码

//css
 .active {
 background: #00FF90;
 }

//html
 <p id="text">
 积土成山,风雨兴焉;积水成渊,蛟龙生焉;积善成德,而神明自得,圣心备焉。
 故不积跬步,无以至千里;不积小流,无以成江海。骐骥一跃,不能十步;驽马十驾,功在不舍。
 锲而舍之,朽木不折;锲而不舍,金石可镂。蚓无爪牙之利,筋骨之强,上食埃土,下饮黄泉,用心一也。
 蟹六跪而二螯,非蛇鳝之穴无可寄托者,用心躁也。
 </p>

//js
function select() {
 let selectedRange = window.getSelection().getRangeAt(0); //获取选中文本位置,返回Range对象
 let selectedFragment = selectedRange.extractContents(); //移除选区文档片段,并返回
 let span = document.createElement("span"); 
 span.classList = 'active';
 span.appendChild(selectedFragment); //创建span标签添加想要的类名,名把返回的文档片段插入
 selectedRange.insertNode(span); //在获取的Range对象中插入span标签
 span.onclick = function(ev) {
 //再点击span标签,在其前面添加span标签内的文本,并删除这个span标签
 this.parentNode.insertBefore(document.createTextNode(this.innerText), this);
 this.parentNode.removeChild(this);
 };
 }
 document.getElementById('text').onmouseup = function() {
 select(); 
 window.getSelection().removeAllRanges(); //鼠标松开后取消浏览器默认的深蓝色选中样式
 };

结语

DOM2和DOM3的功能远不止这些,它有着更加细腻和多样的DOM操作,需要我们去发掘和熟悉。

下载本文
显示全文
专题