正規表現テスターを設計する場合、ユーザー入力を取得して有効な正規表現に変換することが課題となる場合があります。ユーザーが入力を // 区切り文字で囲む必要がない場合、g や i などのフラグを指定できません。ただし、式の前後に // を含めると、文字列を正規表現に変換するという別の障害が発生します。
RegExp コンストラクターを使用した解決策:
解決策は、次のことを利用することにあります。 RegExp オブジェクト コンストラクター。正規表現文字列と任意のフラグの両方を渡すことで、正規表現を直接作成できます。
<code class="javascript">var re = new RegExp("a|b", "i");</code>
これは、省略表記と同等です。
<code class="javascript">var re = /a|b/i;</code>
このアプローチにより、次のことが可能になります。ユーザー入力を文字列として受け入れ、それを変数に抽出し、適切なフラグを使用して正規表現を構築するために使用します。文字列やフラグを解析する必要はなく、RegExp コンストラクターの柔軟性を維持できます。
実装例:
HTML コードでは、次のことができます。ユーザーに正規表現 (// 区切り文字を含む) の入力を求め、それを変数に保存します:
<code class="html"><input type="text" id="regex"></code>
ボタンをクリックしたときの JavaScript コード:
<code class="javascript">var regexInput = document.getElementById('regex').value; var re = new RegExp(regexInput); // Use the re variable for your regular expression operations</code>
このコード// 区切り文字を含むユーザーの入力を受け入れ、提供された構文を使用して正規表現に変換します。
以上がユーザー入力文字列を JavaScript で有効な正規表現に変換するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。