ユーザー入力文字列を JavaScript で有効な正規表現に変換するにはどうすればよいですか?

Mary-Kate Olsen
リリース: 2024-10-30 00:39:02
オリジナル
935 人が閲覧しました

How to Convert User Input Strings into Valid Regular Expressions in JavaScript?

ユーザー入力文字列の正規表現への変換

正規表現テスターを設計する場合、ユーザー入力を取得して有効な正規表現に変換することが課題となる場合があります。ユーザーが入力を // 区切り文字で囲む必要がない場合、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 サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!