我将用户选择的范围存储在变量中。
var sel, range, off, tags;
sel = window.getSelection();
if (sel.rangeCount) {
range = sel.getRangeAt(0);
var off = sel.anchorOffset;
}
else if (document.selection && document.selection.createRange) {
range = document.selection.createRange();
var off = document.selection.anchorOffset;
}
return range;
html
<div ng-mouseup="mouseUpEvent(e)" ng-keyup="keyUpEvent()" contenteditable data-element="textBlock" id="markdown-body">
Chicken ipsum dolor sit amet, consectetur adipiscing elivolutpat volutpat. Nunc imperdiet urna et orci mattis,
pellentesque posuere enim pellentesque. Aenean id orci et nunc venenatis vestibulum et et ligula. Morbi mollis ornare purus
non blandit.<b> Phasellus egestas</b>, ipsum <i>sit amet finibus </i>pellentesque, <span style="color: red;">tellus urna
lobortis tellus, id tincidunt </span>Piza house byys nget lectus. Proin pulvinar enim non mi vestibulum interdum.
Sed nisl enim, sagittis non vestibulum eget, congue pellentesque ipsum. Nullam nec interdum elit
</div>
我找到了我的anchorNode 和我的focusNode。所以我选择了节点名称“B”的节点。代表粗体。
如果我做 element.nodeName 我的输出将是“B”。
如果我输出我的元素,<b> Phasellus egestas</b>
我也会得到一个选定的范围,并且我选择了“asellus eges”
我想删除<b>
标签。并将标签添加到选择范围。如果我取元素的 innerHTML 并替换它,那么我会被选择范围弄乱。
我看到人们建议寻找父节点,而不是选择 childNode 并删除并执行以下操作:
element[index].parentNode.removeChild(element[index]);
但是,如果我的 Parent 有两个具有相同 nodeName 的子节点,这将导致问题。
我已经有了选择特定 Node 的元素,如何保留 innerConnet 和 HTML 标记但删除 b 标签?