gpt4 book ai didi

javascript - 删除所选文本 javascript 之前和之后的特定文本

转载 作者:行者123 更新时间:2023-12-03 07:03:29 25 4
gpt4 key购买 nike

我想删除所选文本之前和之后的一些特定文本。例如,如果文本是:

<p>This is a &lt;random>sentence&lt;/random> that i am writing<p>

如果用户选择文本,则应从文本中删除 ,文本将如下所示。

This is a sentence that i am writing.

如果用户选择“句子”以外的任何内容,则不会发生任何事情。我知道如何选择特定文本,但我不知道下一步如何删除特定文本之前和之后的文本。这可能吗?

最佳答案

function replaceSelection() {
var sel, range, fragment;

if (typeof window.getSelection != "undefined") {
// IE 9 and other non-IE browsers
sel = window.getSelection();

// Test that the Selection object contains at least one Range
if (sel.getRangeAt && sel.rangeCount) {
// Get the first Range (only Firefox supports more than one)
range = window.getSelection().getRangeAt(0);
var selectedText = range.toString();
var replacementText = selectedText.replace(/&lt;\/?random>/, '');
range.deleteContents();

// Create a DocumentFragment to insert and populate it with HTML
// Need to test for the existence of range.createContextualFragment
// because it's non-standard and IE 9 does not support it
if (range.createContextualFragment) {
fragment = range.createContextualFragment(replacementText);
} else {
// In IE 9 we need to use innerHTML of a temporary element
var div = document.createElement("div"), child;
div.innerHTML = replacementText;
fragment = document.createDocumentFragment();
while ( (child = div.firstChild) ) {
fragment.appendChild(child);
}
}
var firstInsertedNode = fragment.firstChild;
var lastInsertedNode = fragment.lastChild;
range.insertNode(fragment);
if (selectInserted) {
if (firstInsertedNode) {
range.setStartBefore(firstInsertedNode);
range.setEndAfter(lastInsertedNode);
}
sel.removeAllRanges();
sel.addRange(range);
}
}
} else if (document.selection && document.selection.type != "Control") {
// IE 8 and below
range = document.selection.createRange();
var selectedText = range.text;
var replacementText = selectedText.replace(/&lt;\/?random>/, '')
range.pasteHTML(replacementText);
}
}
<div onmouseup="replaceSelection()"><p>This is a &lt;random>sentence&lt;/random> that i am writing<p></div>

关于javascript - 删除所选文本 javascript 之前和之后的特定文本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36930651/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com