最近、プロジェクトに取り組んでいるときに、Web ページ上のキーワードを強調表示する機能に遭遇しました。 innerHTML の置換で実現できる簡単な操作だと思っていましたが、多くの問題に遭遇しました。この記事では、これらの問題と最終的な完璧な解決策を記録し、同じ経験をした友人の役に立つことを願っています。結果だけに興味がある場合は、プロセスを無視して結果に進んでください。 一般的な方法:定期的な交換 アイデア: 要素を強調表示するには、キーワードを抽出してタグで囲み、タグのスタイルを調整する必要があります。 innerText または outText の代わりに innerHTML または outHTML を使用します。 const regex = 新しい RegExp(キーワード、"g") element.innerHTML = element.innerHTML.replace(正規表現、"<b class="a">"+キーワード+"</b>") element.classList.add("ハイライト") これを行うと、次のような隠れた危険が生じます。 ()\ 分割 <div id="親"> <div class="test">テスト</div> </div> キーワード親ノード要素は、クラスを使用して背景色付けを実行します。これにより、元の DOM がある程度汚染され、要素の再配置に影響する可能性があります。 (プラグインなので、元のDOMをできるだけ変更しないことが望まれます) 通常の最適化1: タグ内の要素のみを処理する var formatKeyword = text.replace(/[-\/\\^$*+?.()|[\]{}]/g, '\\$&') // キーワードに含まれる / などの特殊文字をエスケープします。 var finder = new RegExp(">.*?"++".*?<") // クラスやIDなどの誤操作を避けるためにタグ内のテキストを抽出します。 element.innerHTML = element.innerHTML.replace(finder,function(matched){ matched.replace(text,"<br>"+text+</br>) を返します }) // 抽出したタグテキスト内のキーワードを置き換える これでほとんどの問題は解決できますが、タグ属性に < のような記号がある限り、一致ルールが破られ、通常の抽出コンテンツが不正確になるという問題がまだ残っています。HTML5 データセットは任意のコンテンツをカスタマイズできるため、これらの特殊文字は避けられません。 <div dataset="p>d">置換</div> 通常の最適化2: 影響を受ける可能性のあるラベルをクリアする <div id="keyword">キーワード</div> =》終了タグを変数 [replaced1] キーワード [replaced2] に置き換えます // 終了タグ内の id="keyword" は処理されません =》 [置換1]<b>キーワード</b>[置換2] =》一時変数を元のタグ <div id="keyword"><b>keyword</b></div> に置き換えます
最も重要なことは、タグ値に <> 記号が含まれている場合、この方法ではタグを正しく抽出できないことです。 つまり、多くの試行を経ても、正規表現はさまざまな状況を効果的に処理することができませんでした。その後、考え方を変えて、文字列ではなくノードを通じて処理するようになりました。 element.childNodes は、タグ内のノイズ情報を最も効果的にクリーンアップできます。 [完璧な解決策] DOMノードを介した処理 <div id="親"> キーワード1 <span id="子"> キーワード2 </span> </div> parent.childNodes を通じてすべての子ノードを取得します。次のように、子ノードを ただし、キーワード 1 はテキスト ノードであり、テキスト コンテンツを変更することしかできず、HTML を追加することはできず、そのスタイルを個別に制御することもできません。そして、テキストノードは通常のノードに変換できないため、これが最も厄介な点です。 最後に、この記事の焦点はここにあります。この機能のおかげで、私は初めてテキストノードについて真剣に知るようになりました。ここからテキストが検出され、テキスト ノードを切り取って置き換えることで強調表示が実現されます。 ソースコードとハイライトの復元、ソースコードを参照 const reg = new RegExp(keyword.replace(/[-\/\\^$*+?.()|[\]{}]/g, '\\$&')) ハイライト = 関数 (ノード、reg){ if (node.nodeType == 3) { //テキストノードのみ処理 const match = node.data.match(new RegExp(reg)); (一致)の場合{ const highlightEl = document.createElement("b"); highlightEl.dataset.highlight="y" 定数 wordNode = node.splitText(match.index) wordNode.splitText(match[0].length); // 最初のキーワードと最後の3つのテキストノードに分割します。const wordNew = document.createTextNode(wordNode.data); highlightEl.appendChild(wordNew);//ハイライトノードが正常に構築されました wordNode.parentNode.replaceChild(highlightEl, wordNode);//テキストノードを置き換えます} } そうでない場合 (node.nodeType == 1 && node.dataset.highlight!="y" ){ (var i = 0; i < node.childNodes.length; i++) { ハイライト(node.childNodes[i], reg); 私は++ } } } 要約する 上記は、HTML でキーワードを強調表示するための完璧なソリューションです。お役に立てれば幸いです。ご質問がある場合は、メッセージを残してください。すぐに返信いたします。また、123WORDPRESS.COM ウェブサイトをサポートしてくださっている皆様にも感謝申し上げます。 |
<<: モバイル開発におけるHTML5開発の現状を深く理解する
<br />関連記事: Web コンテンツ ページ作成に関する 9 つの実用的な提案 W...
ただし、デフォルトの src を持つ <img> 要素を使用してスクロール読み込み効果を...
VirtualBoxのHost Only+NATモードのネットワーク構成は参考用です。具体的な内容は...
序文MySQL の権限テーブルは、データベースの起動時にメモリにロードされます。ユーザーが ID 認...
エンジニアリング構造プロジェクトは2つの部分に分かれています。bilibili-apiはAPIインタ...
目次1 マスター・スレーブの読み取り・書き込み分離1.1 コア2 マスタースレーブレプリケーション2...
この記事の例では、ログイン機能を実現するためのvue+springbootの具体的なコードを参考まで...
まず、github から nacos の圧縮パッケージをダウンロードします: https://git...
Vue で SVG アイコンを導入する方法Vue で svg アイコンを導入する方法 1インストール...
目次シナリオ効果コード要約するシナリオ登録ページに携帯電話番号を入力し、登録インターフェイスを要求す...
まずは簡単なデータを見てみましょう。 Googleが発表したレポートによると、 ①中国の都市の97%...
基本的な構文text-overflow を使用するには、hight、over-flow:hidden...
1. テーブル リセットの 2 つのプロパティ: ①border-collapse: collaps...
ウェブページを作り始めたばかりの友人の多くは、拡張子が非常に多いことに気づきます。実際、htm と ...
Nginx ログの説明アクセス ログを通じて、ユーザーの地理的起源、ジャンプ元、使用端末、特定の U...