> 웹 프론트엔드 > JS 튜토리얼 > RegExp의 `test()` 메소드가 전역 플래그와 대소문자를 구분하지 않는 플래그를 사용하여 예기치 않은 결과를 반환하는 이유는 무엇입니까?

RegExp의 `test()` 메소드가 전역 플래그와 대소문자를 구분하지 않는 플래그를 사용하여 예기치 않은 결과를 반환하는 이유는 무엇입니까?

Barbara Streisand
풀어 주다: 2024-12-24 20:37:17
원래의
325명이 탐색했습니다.

Why Does RegExp's `test()` Method Return Unexpected Results with Global and Case-Insensitive Flags?

글로벌 플래그와 대소문자를 구분하지 않는 플래그를 사용하는 RegExp는 예상치 못한 결과를 낳습니다

질문:

전역 플래그(g)와 대소문자를 구분하지 않는 플래그(i), 테스트 방법이 왜 잘못된 결과를 생성합니까? 사용자 생성 입력?

예:

다음 코드를 고려하세요.

var query = 'Foo B';
var re = new RegExp(query, 'gi');
var result = [];
result.push(re.test('Foo Bar'));
result.push(re.test('Foo Bar'));
// result will be [true, false]
로그인 후 복사

예상 결과: [true, true]

설명:

g 플래그가 있는 RegExp 객체는 마지막 일치 항목의 위치를 ​​나타내는 lastIndex 속성을 유지합니다. lastIndex를 재설정하지 않고 테스트 메서드를 반복적으로 호출하면 0부터 시작하지 않고 마지막으로 사용한 인덱스부터 검색을 다시 시작합니다.

데모:

var query = 'Foo B';
var re = new RegExp(query, 'gi');
console.log(re.lastIndex); // 0

console.log(re.test('Foo Bar')); // true
console.log(re.lastIndex); // 6

console.log(re.test('Foo Bar')); // false
console.log(re.lastIndex); // 6
로그인 후 복사

위의 예에서 test에 대한 첫 번째 호출은 lastIndex를 6으로 설정합니다. 이어서 두 번째 호출은 인덱스 6에서 검색을 재개하며 결과적으로 검색 결과는 false입니다. 범위는 마지막 일치 문자 다음의 문자로 제한됩니다.

위 내용은 RegExp의 `test()` 메소드가 전역 플래그와 대소문자를 구분하지 않는 플래그를 사용하여 예기치 않은 결과를 반환하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿