最近、JS の正規表現マッチングの落とし穴を発見したのですが、その時はあまりにも奇妙だったので、何か超常現象が起こっているのではないかと疑うほどでした。 以下はピットコードです var str=["二七1","二七2","金水","二七3","二七4","二七5"] var reg = new RegExp ("二七", "g"); for(var i=0;i<str.length;i++){ if(reg.test(str[i])){ コンソールログ(str[i]) } } 正規表現を使用してstrをグローバルに一致させ、条件に合致したときにそれを出力します。 明らかな理由なく 2 つが欠落しており、それらについては別途判断します。 var str=["二七1","二七2","金水","二七3","二七4","二七5"] var reg = new RegExp ("二七", "g"); for(var i=0;i<str.length;i++){ if(reg.test(str[i])){ コンソールログ(str[i]) } もし(i==1){ コンソールログ(reg.test(str[i])) } もし(i==4){ コンソールログ(reg.test(str[i])) } } それで私はこれを手に入れました もう 1 つが欠けていますが、欠けている 2 つは規則性チェックを満たしていることがわかります。その後、インターネットで次の文章を見つけました。 文字列が正規表現で正常に一致した場合、lastIndex は、文字列グローバル一致の次の検索の開始点として、最初に一致した文字列の位置に設定されます。後続のフィールドが正常に一致した場合、一致が失敗するまで lastIndex が繰り返し再割り当てされ、0 にリセットされます。 しかし、先生に聞いたところ、一致が見つかった後はlastIndex+1が返されると教えてくれました。つまり、最初に一致したとき、lastIndexは2でした。この2は文字列の添え字であり、配列の添え字ではありません。したがって、str[1]を判断するときは、0からではなく、文字列の添え字2から始まります。したがって、2番目の判断は偽であり、一致は失敗します。LastIndexは0に設定されているため、3番目の一致は成功できます。 したがって、判定結果が true になると、lastIndex は 0 に設定され、データは正常になります。 データは正常です。 要約する グローバル マッチングを使用する場合、各検索後に lastIndex が 0 に設定されるか、グローバル マッチングは使用されず、直接マッチングが実行されます。 ネットユーザーのまとめは以下のとおりです。
困っている友人は参考にしてください。JS 正規マッチングの落とし穴の記録に関するこの記事はこれで終わりです。より関連性の高い JS 正規マッチングの落とし穴については、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM を応援してください。 以下もご興味があるかもしれません:
|
<<: 2 級コンピュータ試験のための MySQL の知識ポイントとよく使用される MYSQL コマンド
>>: tomcatでcatalina.outログをカットする3つの方法の詳細な説明
1. はじめにtelnet コマンドは、リモート ホストにログインするために使用されます。これは、T...
MySQL データベースをインストールすると、デフォルトの MySQL データベースの最大接続数が ...
目次序文フロントエンドモジュール開発の価値厄介な名前の競合面倒なファイル依存関係モジュール化の利点C...
効果を直接確認するために、リロード、左を閉じる、右を閉じる、その他の機能を閉じるなどの右クリック メ...
レイアウトを編集するとき、通常は水平センタリングと垂直センタリングを使用してデザインします。水平セン...
フレキシブル レイアウト (Flexbox) はますます人気が高まっており、CSS レイアウトの記述...
MySQL 8.0: InnoDB のラージ オブジェクトに対する MVCCこの記事では、MySQL...
技術的背景Latex は文書作成、特に記事作成には欠かせないツールであり、必須のテキスト組版ツールで...
需要シナリオ:上司は、クローラーを使用してMySQLデータベースにデータを書き込んだり更新したり...
目次1. JavaScript における数値2. Javascript の Math オブジェクト1...
目次日時タイムスタンプ選び方ミリ秒の時間を保存する方法結論MySQL は、日付と時刻を処理するために...
導入前回の記事では、axios のシンプルなカプセル化と、axios インターセプターの適用シナリオ...
この記事では、MySQL 8.0.16圧縮パッケージのインストールと設定方法を参考までに紹介します。...
目次序文ドローコールとはDrawCall はパフォーマンスにどのような影響を与えますか?ドローコール...
ガラス窓今日実現するのは雨滴効果です。ただし、雨滴効果を実現する前に、まずは曇りガラス効果を作成しま...