最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

如何为选择的文本添加一个类名(js+css实现)

来源:懂视网 责编:小采 时间:2020-11-27 19:32:20
文档

如何为选择的文本添加一个类名(js+css实现)

如何为选择的文本添加一个类名(js+css实现):本篇文章给大家带来的内容是关于如何为选择的文本添加一个类名(js+css实现),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。最近做个小功能,功能效果如图:试想一下,如果在选择文本之后不仅能获得对应文档片段,而且再获得文本对应的文档
推荐度:
导读如何为选择的文本添加一个类名(js+css实现):本篇文章给大家带来的内容是关于如何为选择的文本添加一个类名(js+css实现),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。最近做个小功能,功能效果如图:试想一下,如果在选择文本之后不仅能获得对应文档片段,而且再获得文本对应的文档

这样的话咱们先来学习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一下看看这个属性所在位置

2844326387-5b7170e245dc8_articlex.jpg

2. Range.extractContents()

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

3. Range.insertNode(

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

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

560963292-5b72b98f529d6_articlex.jpg

接下来就上代码

//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操作,需要我们去发掘和熟悉。

文档

如何为选择的文本添加一个类名(js+css实现)

如何为选择的文本添加一个类名(js+css实现):本篇文章给大家带来的内容是关于如何为选择的文本添加一个类名(js+css实现),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。最近做个小功能,功能效果如图:试想一下,如果在选择文本之后不仅能获得对应文档片段,而且再获得文本对应的文档
推荐度:
标签: 一个 如何 选择
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top