ホームページ >ウェブフロントエンド >jsチュートリアル >JavaScript 正規表現で一致したグループにアクセスするにはどうすればよいですか?

JavaScript 正規表現で一致したグループにアクセスするにはどうすればよいですか?

Mary-Kate Olsen
Mary-Kate Olsenオリジナル
2024-12-29 16:42:18905ブラウズ

How Can I Access Matched Groups in JavaScript Regular Expressions?

JavaScript 正規表現で一致したグループにアクセスする

正規表現を使用して文字列内のパターンと一致する場合、多くの場合、一致したテキスト。 JavaScript には、これを実現するためのいくつかの方法が用意されています。

この例では、括弧付きの正規表現を正しく使用して文字列の一部をキャプチャしました。ただし、発生した問題は正規表現自体ではなく、一致したグループへのアクセス方法にありました。

.exec() を使用したグループへのアクセス

exec() メソッドは、最初の要素として一致した文字列全体を含む配列を返し、その後にキャプチャされたグループが続きます。最初にキャプチャされたグループ (この例では「abc」の部分) にアクセスするには、arr[1]:

let myString = "something format_abc";
let arr = /(?:^|\s)format_(.*?)(?:\s|$)/.exec(myString);

console.log(arr[1]); // Prints: abc

Using Named Capture Groups

を使用します。 (?) のような正規表現構文を使用してキャプチャ グループに名前を付けることもできます。これにより、キャプチャされたテキストに名前でアクセスできるようになります:

let myString = "something format_abc";
let arr = /(?:^|\s)format_(?<text>.*?)(?:\s|$)/.exec(myString);

console.log(arr.groups.text); // Prints: abc

名前付きキャプチャ グループを使用した代替構文:

ECMAScript 2018 では、少し異なる構文を使用できます。名前付きキャプチャ グループの構文。グループ名を中括弧で囲みます。 braces:

let myString = "something format_abc";
let arr = /(?:^|\s)format_({text}.*?)(?:\s|$)/.exec(myString);

console.log(arr.groups.text); // Prints: abc

.matchAll() を使用した複数の出現の一致

.matchAll() メソッドは ECMAScript 2020 で導入され、イテレータベースの API を提供します。文字列内のパターンの複数の出現と一致します。これは、一致ごとに一致結果を配列として生成する反復子を返し、各結果内のキャプチャされたグループにアクセスできます。

例で .matchAll() を使用するには:

let myString = "something format_abc and something format_xyz";
let matches = myString.matchAll(/(?:^|\s)format_(.*?)(?:\s|$)/g);

for (let match of matches) {
  console.log(match[1]); // Prints: abc, then xyz
}

以上がJavaScript 正規表現で一致したグループにアクセスするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。