您好,欢迎访问一九零五行业门户网

如何为选择的文本添加一个类名(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一下看看这个属性所在位置
2. range.extractcontents()extractcontents(),会从文档中移除范围选区,并返回范围的文档片段,这样就获得了想要的文档片段。3. range.insertnode(insertnode(),是在range的起始位置插入节点的方法。详细属性可以自行参考mdn或者高程
console一下看看上两个属性所在位置
接下来就上代码//css .active {        background: #00ff90;    }//html <p id="text">    积土成山,风雨兴焉;积水成渊,蛟龙生焉;积善成德,而神明自得,圣心备焉。    故不积跬步,无以至千里;不积小流,无以成江海。骐骥一跃,不能十步;驽马十驾,功在不舍。    锲而舍之,朽木不折;锲而不舍,金石可镂。蚓无爪牙之利,筋骨之强,上食埃土,下饮黄泉,用心一也。    蟹六跪而二螯,非蛇鳝之穴无可寄托者,用心躁也。 </p>//jsfunction 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操作,需要我们去发掘和熟悉。
相关推荐:
javascript类名的添加与移除的实现代码分享
二级归类添加文章
以上就是如何为选择的文本添加一个类名(js+css实现)的详细内容。
其它类似信息

推荐信息