[解決済み] Javascript + Regex = エラーを繰り返すことはない?
2022-02-01 05:01:15
質問
私はREGEXの初心者ですが、REGEXを学んで自分のスキルのレパートリーに加えられるかどうか、新しいプロジェクトの1つに取り入れようとしています。しかし、私はここで障害にぶつかっています。
ユーザーの入力に不正な文字が含まれていないかどうかを、ユーザーインターフェースの
.search
という関数があります。
if (name.search("[\[\]\?\*\+\|\{\}\\\(\)\@\.\n\r]") != -1) {
...
}
しかし、この行が含まれている関数を実行しようとすると、その特定の行に対して次のようなエラーが投げられます。
Uncaught SyntaxError: Invalid regular expression: /[[]?*+|{}\()@.
]/: Nothing to repeat
私のコードのどこが問題なのか、どうしてもわかりません。どなたか正しい方向を示していただけませんか?
解決方法は?
正規表現の特殊文字をエスケープするために使用されるバックスラッシュを2重にする必要があります。 しかし、@Bohemianが指摘するように、これらのバックスラッシュのほとんどは必要ありません。 残念ながら、彼の回答はあなたの回答と同じ問題を抱えています。 あなたが実際に望んでいるのは
バックスラッシュは、正規表現パーサーに渡されるのではなく、文字列を読み取るコードによって解釈されます。 あなたが欲しいのは
"[\\[\\]?*+|{}\\\\()@.\n\r]"
バックスラッシュが4つになっていることに注意してください。 これは間違いなく必要です。 正規表現コンパイラに渡される文字列は、@Bohemian の文字列と同じであり、正しく動作します。
関連
-
[解決済み】Google Conversionsが動作しない - スクリプトが読み込まれない
-
[解決済み】ETIMEDOUTエラーの対処方法は?
-
[解決済み] JavaScriptで "use strict "は何をするのか、その根拠は?
-
[解決済み] JavaScriptで文字列が部分文字列を含むかどうかを確認する方法は?
-
[解決済み] あるJavaScriptファイルを他のJavaScriptファイルにインクルードするにはどうすればよいですか?
-
[解決済み] JavaScriptでメールアドレスを検証するのに最適な方法は何ですか?
-
[解決済み] JavaScriptでタイムスタンプを取得する方法は?
-
[解決済み】JavaScriptの比較では、どちらの等号演算子(== vs ===)を使うべきですか?
-
[解決済み】JavaScriptで文字列の出現箇所をすべて置換する方法
-
[解決済み】オブジェクトからプロパティを削除する(JavaScript)
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】Facebook Graph API のクエリで with=location を使用すると "Uncaught (in promise) undefined" というエラーが発生する。
-
[解決済み】document.getElementByIDは関数ではありません。
-
[解決済み】webpack-dev-serverにリモート接続すると、「Invalid Host header」というメッセージが表示されます。
-
[解決済み】コンソールがUnterminated JSX contentsエラーを投げる【終了しました
-
[解決済み】ある要素を別の要素に移動させるには?
-
[解決済み】React.jsの配列の子要素のユニークキーを理解する
-
[解決済み】TypeError: res.status は関数ではありません。
-
[解決済み】ES6マップオブジェクトをソートすることは可能ですか?
-
[解決済み】 Uncaught Reference Error: stLight is not defined (in Chrome only)
-
[解決済み】Vueが定義されていない