> 웹 프론트엔드 > JS 튜토리얼 > JavaScript 정규 표현식에서 부정적 Lookbehind를 어떻게 시뮬레이션할 수 있습니까?

JavaScript 정규 표현식에서 부정적 Lookbehind를 어떻게 시뮬레이션할 수 있습니까?

Barbara Streisand
풀어 주다: 2024-12-14 15:48:11
원래의
634명이 탐색했습니다.

How Can I Simulate Negative Lookbehind in JavaScript Regular Expressions?

Negative Lookbehind에 해당하는 JavaScript

특정 문자 집합으로 시작하지 않는 문자열과 일치하는 Negative Lookbehind는 직접 지원되지 않습니다. 자바스크립트 정규식. 그러나 유사한 결과를 얻기 위한 대체 접근 방식이 있습니다.

긍정적 예측 및 문자열 반전

JavaScript는 긍정적 예측(?=)을 지원하므로 한 가지 방법은 다음과 같습니다.

  1. 입력 문자열을 반대로 합니다.
  2. 긍정적인 예측으로 정규식을 역전시켰습니다.

예:

const reverse = s => s.split('').reverse().join('');
const regexp = /m(?!([abcdefg]))/;

test(['jim', 'm', 'jam'], regexp);

function test(strings, regexp) {
  strings.map(reverse).forEach((s, i) => {
    match = regexp.test(s);
    console.log(strings[i], match, 'Token: ', match ? reverse(regexp.exec(s)[0]) : 'Ø');
  });
}
로그인 후 복사

결과:

jim true Token: m
m true Token: m
jam false Token: Ø
로그인 후 복사

Lookbehind Assertions 지원(이후 2018)

2018년에는 부정적인 LookBehind를 포함한 LookBehind 어설션이 ECMAScript 언어 사양의 일부가 되었습니다. 다음과 같이 사용할 수 있습니다.

부정적 뒤돌아보기:

(?<!...)
로그인 후 복사

긍정적 뒤돌아보기:

(?<=...)
로그인 후 복사

예:

"max-height"와 일치하지만 일치하지 않음 "line-height":

regexp = /thgieh(?!(-enil))/;
test(['max-height', 'line-height'], regexp);
로그인 후 복사

결과:

max-height true Token: height
line-height false Token: Ø
로그인 후 복사

위 내용은 JavaScript 정규 표현식에서 부정적 Lookbehind를 어떻게 시뮬레이션할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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