>웹 프론트엔드 >JS 튜토리얼 >JavaScript 정규 표현식에서 일치하는 그룹에 어떻게 액세스할 수 있나요?

JavaScript 정규 표현식에서 일치하는 그룹에 어떻게 액세스할 수 있나요?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-29 16:42:18907검색

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

명명된 캡처 그룹 사용

을 사용합니다. (?)과 같은 정규식 구문을 사용하여 캡처 그룹의 이름을 지정할 수도 있습니다. 이를 통해 캡처된 텍스트에 이름으로 액세스할 수 있습니다:

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

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

명명된 캡처 그룹을 사용한 대체 구문:

ECMAScript 2018에서는 약간 다른 구문을 사용할 수 있습니다. 이름이 지정된 캡처 그룹에 대한 구문(그룹 이름을 곱슬로 묶음) 중괄호:

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.