Maison >interface Web >js tutoriel >Comment puis-je simuler un lookbehind négatif dans des expressions régulières JavaScript ?

Comment puis-je simuler un lookbehind négatif dans des expressions régulières JavaScript ?

Barbara Streisand
Barbara Streisandoriginal
2024-12-14 15:48:11719parcourir

How Can I Simulate Negative Lookbehind in JavaScript Regular Expressions?

Équivalent JavaScript du lookbehind négatif

Les lookbehinds négatifs, qui correspondent à des chaînes qui ne commencent pas par un jeu de caractères spécifique, ne sont pas directement pris en charge par Expressions régulières JavaScript. Cependant, il existe des approches alternatives pour obtenir des résultats similaires.

Avis positif et inversion de chaîne

Étant donné que JavaScript prend en charge l'anticipation positive (?=), une méthode implique :

  1. Inverser la chaîne d'entrée.
  2. Utiliser une expression régulière inversée avec du positif lookahead.
  3. Inverser et reformater les correspondances.

Exemple :

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]) : 'Ø');
  });
}

Résultats :

jim true Token: m
m true Token: m
jam false Token: Ø

Prise en charge des assertions Lookbehind (Depuis 2018)

En 2018, les assertions lookbehind, y compris les lookbehinds négatifs, sont devenues partie intégrante de la spécification du langage ECMAScript. Ils peuvent être utilisés comme suit :

Lookbehind négatif :

(?<!...)

Lookbehind positif :

(?<=...)

Exemple :

Pour correspondre "max-height" mais pas "line-height":

regexp = /thgieh(?!(-enil))/;
test(['max-height', 'line-height'], regexp);

Résultats :

max-height true Token: height
line-height false Token: Ø

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn