使用正则表达式Javascript检索文本的parentNode

Sla*_*ner 5 html javascript

我有一个RegEX:

var re = RegExp("(?:^\\W*|(" + motBefore.replace(/[.*+?^${}()|[\]\\]/g, "\\$&") + ")\\W+)" + motErreur.replace(/[.*+?^${}()|[\]\\]/g, "\\$&") + "(?:\\W+(" + motAfter.replace(/[.*+?^${}()|[\]\\]/g, "\\$&") + ")|\\W*$)", "g"); 
Run Code Online (Sandbox Code Playgroud)

有了这个RegEX,我可以在我的页面中找到关于定位的某个词的位置(就像这个我没有多次出现,如果它不是我想要的那个).

我想用跨度来调整motErreur.事实是我不能通过简单的替换和改变innerHTML来做到这一点,因为它弄乱了我的页面的标签.

我在用 :

var result = document.getElementById('edth_corps');
var textRangeGlobal = document.body.createTextRange();
textRangeGlobal.moveToElementText(result);
if(textRangeGlobal.findText(motErreur)){
    var html= "<span id='"+nbId+"' class='erreurOrthographe' oncontextmenu='rightClickMustWork(event, this);return false'>" + motErreur + "</span>";
    textRangeGlobal.pasteHTML(html);
}
Run Code Online (Sandbox Code Playgroud)

我想要的var result不是document.getElementById('edth_corps');我用RegEX获得结果的节点.

我在IE5上,无法弄清楚如何使用RegEx获取节点(我试过match但它没有用.

有人有想法怎么做?

tnt*_*rox 0

使用正则表达式并不是解决这个问题的好方法。您最好创建一个 dom 元素并使用 dom 遍历来删除不需要的元素。您可以执行类似于以下代码:

var wrap = document.createElement('div');
wrap.innerHTML = "your html";
Run Code Online (Sandbox Code Playgroud)

现在您可以使用 dom 选择器来处理“虚拟”元素。并将节点附加到 dom

target.appendChild(wrap.firstElementChild.cloneNode(true);
Run Code Online (Sandbox Code Playgroud)