これは私が数年前に書いた関数で、特定のテキストを検索し、それらを強調表示します(ヒットをspan
特定のクラス名でに入れます)。
DOMツリーをたどり、テキストの内容を調べます。検索されたテキストを含むテキストノードが見つかると、そのテキストノードが3つの新しいノードに置き換えられます。
- 一致の前にテキストがある1つのテキストノード、
- 一致するテキストを含む1つの(新しく作成された)
span
要素、
- 一致に続くテキストを含む1つのテキストノード。
これは私が持っている機能です。これはより大きなスクリプトファイルの一部ですが、独立して実行する必要もあります。ensureElementVisible
(スクリプトには折りたたみ機能と拡張機能もあるため、要素を表示する呼び出しをコメントアウトしました)。
それはおそらくあなたが必要としないであろう一つの(他の)ことをします:それは検索テキストを複数の単語のいずれかに一致する正規表現に変えます。
function findText(a_text, a_top) {
// Go through *all* elements below a_top (if a_top is undefined, then use the body)
// and check the textContent or innerText (only if it has textual content!)
var rexPhrase = new RegExp(a_text.replace(/([\\\/\*\?\+\.\[\]\{\}\(\)\|\^\$])/g, '\\$1').replace(/\W+/g, '\\W*')
, 'gi');
var terms = [];
var rexSearchTokens = /[\w]+/g;
var match;
while(match = rexSearchTokens.exec(a_text)) {
terms.push(match[0]);
}
var rexTerm = new RegExp('\\b(' + terms.join('|') + ')', 'gi');
var hits = [];
walkDOMTree(a_top || document.body,
function search(a_element) {
if (a_element.nodeName === '#text') {
if(rexPhrase.test(a_element.nodeValue)) {
// ensureElementVisible(a_element, true);
hits.push(a_element);
}
}
});
// highlight the search terms in the found elements
for(var i = 0; i < hits.length; i++) {
var hit = hits[i];
var parent = hit.parentNode;
if (parent.childNodes.length === 1) {
// Remove the element from the hit list
hits.splice(i, 1);
var text = hit.nodeValue;
parent.removeChild(hit);
var match, prevLastIndex = 0;
while(match = rexTerm.exec(text)) {
parent.appendChild(document.createTextNode(text.substr(prevLastIndex, match.index - prevLastIndex)));
var highlightedTerm = parent.appendChild(document.createElement('SPAN'));
highlightedTerm.className = 'search-hit';
highlightedTerm.appendChild(document.createTextNode(match[0]));
prevLastIndex = match.index + match[0].length;
// Insert the newly added element into the hit list
hits.splice(i, 0, highlightedTerm);
i++;
}
parent.appendChild(document.createTextNode(text.substr(prevLastIndex)));
// Account for the removal of the original hit node
i--;
}
}
return hits;
}