Cette page a été traduite à partir de l'anglais par la communauté.Vous pouvez contribuer en rejoignant la communauté francophone sur MDN Web Docs.
RegExp
Baseline Widely available *
Cette fonctionnalité est bien établie et fonctionne sur de nombreux appareils et versions de navigateurs. Elle est disponible sur tous les navigateurs depuis juillet 2015.
* Certaines parties de cette fonctionnalité peuvent bénéficier de prise en charge variables.
Un objetRegExp est utilisé pour étudier les correspondances d'un texte avec un motif donné.
Pour une introduction aux expressions rationnelles, lirele chapitre Expressions rationnelles dansle Guide JavaScript.
Dans cet article
Description
>Notation littérale et constructeur
Il existe deux façons de créer un objetRegExp : unenotation littérale ou unconstructeur.
- La notation littérale est délimitée par des barres obliques (slashes) et n'utilise pas de quotes
- Pour le constructeur, les paramètres passés ne sont pas délimités par des barres obliques mais par des quotes.
Ainsi, les expressions suivantes créent le même objet d'expression rationnelle :
/ab+c/i; // notation littéralenew RegExp("ab+c", "i"); // constructeurnew RegExp(/ab+c/, "i"); // notation littérale dans un constructeurLa notation littérale effectue la compilation de l'expression rationnelle lorsque l'expression est évaluée. Utilisez la notation littérale lorsque l'expression rationnelle reste constante. Par exemple, si vous utilisez la notation littérale pour construire une expression rationnelle utilisée dans une boucle, l'expression rationnelle ne sera pas recompilée à chaque itération.
Le constructeur de l'objet expression rationnelle, par exemplenew RegExp('ab+c'), effectue la compilation de l'expression rationnelle au moment de l'exécution. Utilisez le constructeur quand vous savez que le motif d'une expression rationnelle sera variable, ou si vous ne connaissez pas le motif et que vous l'obtiendrez d'une autre source, comme un champ de saisie.
Utiliser des marqueurs avec le constructeur
À partir d'ECMAScript 6,new RegExp(/ab+c/, 'i') ne déclenche plus d'exceptionTypeError ("can't supply flags when constructing one RegExp from another") lorsque le premier argument est une expression rationnelle et que le second argumentmarqueurs est présent. Une nouvelleRegExp sera créée à la place à partir des arguments.
Lorsqu'on utilise le constructeur, les règles normales d'échappement de chaîne (le fait de faire précéder d'un \ les caractères spéciaux à l'intérieur d'une chaîne) sont requises.
Par exemple, les définitions suivantes sont équivalentes :
var re = /\w+/;var re = new RegExp("\\w+");Propriétés semblables à Perl
Plusieurs des propriétés deRegExp ont un nom long et un nom court (semblable à celui utilisé par le langage Perl). Les deux noms font référence à la même valeur. Cela vient du fait que les expressions rationnelles JavaScript ont été conçues en s'inspirant des expressions rationnelles Perl). Voir aussiles propriétés dépréciées deRegExp.
Constructeur
RegExp()Crée un nouvel objet
RegExp.
Propriétés statiques
get RegExp[@@species]La fonction de construction qui est utilisée pour créer des objets dérivés.
Propriétés des instances
RegExp.prototype.flagsUne chaîne de caractères contenant les marqueurs de l'objet
RegExp.RegExp.prototype.dotAllIndique si
.correspond aux sauts de ligne.RegExp.prototype.globalIndique si l'expression rationnelle cherche l'ensemble des correspondances dans la chaîne de caractères ou uniquement la première.
RegExp.prototype.hasIndicesIndique si le résultat de l'expression rationnelle indiquera les indices de début et de fin des sous-chaînes capturées.
RegExp.prototype.ignoreCaseIndique si la casse est ignorée pour la recherche de correspondances dans une chaîne de caractères.
RegExp.prototype.multilineIndique si la recherche de correspondances dans une chaîne se fait sur plusieurs lignes.
RegExp.prototype.sourceLe texte du motif recherché.
RegExp.prototype.stickyIndique si la recherche est adhérente.
RegExp.prototype.unicodeIndique si les fonctionnalités Unicode sont activées.
RegExp: lastIndexL'indice à partir duquel chercher la prochaine correspondance.
Méthodes des instances
RegExp.prototype.compile()Obsolète(Re)compile une expression rationnelle lors de l'exécution d'un script.
RegExp.prototype.exec()Exécute une recherche de correspondance sur la chaîne de caractères passée en argument.
RegExp.prototype.test()Teste la présence d'une correspondance sur la chaîne de caractères passée en argument.
RegExp.prototype.toString()Renvoie une chaîne de caractères représentant l'objet. Il s'agit d'une surcharge de la méthode
Object.prototype.toString().RegExp.prototype[@@match]()Recherche une correspondance sur la chaîne de caractères donnée en argument et renvoie le résultat de la correspondance.
RegExp.prototype[@@matchAll]()Renvoie l'ensemble des correspondances entre l'expression rationnelle et la chaîne de caractères passée en argument.
RegExp.prototype[@@replace]()Remplace les correspondances trouvées sur la chaîne de caractères passée en argument par une nouvelle sous-chaîne.
RegExp.prototype[@@search]()Recherche une correspondance sur la chaîne de caractères donnée en argument et renvoie l'indice à partir duquel le motif a été trouvé dans la chaîne.
RegExp.prototype[@@split]()Découpe une chaîne de caractères donnée en argument en un tableau.
Exemples
>Utiliser une expression rationnelle pour modifier un format de données
Dans le script suivant, on utilise la méthodereplace() deString pour effectuer une correspondance sur le prénom et le nom pour les inverser.
On utilise des parenthèses capturantes pour pouvoir utiliser les correspondances dans la construction du résultat (avec$1 et$2).
let re = /(\w+)\s(\w+)/;let chaine = "Alain Dupont";let nouvelleChaine = chaine.replace(re, "$2, $1");console.log(nouvelleChaine);// Dupont, AlainUtiliser une expression rationnelle pour découper des lignes avec différents sauts de ligne/fins de ligne
La fin de ligne par défaut dépend de la plateforme (Unix, Windows, etc.). Cette méthode de découpage fournie permet de découper indépendamment de la plateforme utilisée.
let texte = "Un texte\net un autre\r\npuis ensuite\rla fin";let lignes = texte.split(/\r\n|\r|\n/);console.log(lignes); // affiche [ 'Un texte', 'et un autre', 'puis ensuite', 'la fin' ]On notera que l'ordre des modèles dans l'expression rationnelle est important.
Utiliser une expression rationnelle sur plusieurs lignes
let s = "Et voici\nune autre ligne !";s.match(/voici.*ligne/);// Renvoie nulls.match(/voici[^]*ligne/);// Renvoie ['voici\nune autre ligne']Utiliser une expression rationnelle avec le marqueur d'adhérence
Cet exemple illustre comment on peut utiliser le marqueursticky qui recherche une correspondance aprèsRegExp.prototype.lastIndex.
let str = "#toto#";let regex = /toto/y;regex.lastIndex = 1;regex.test(str); // trueregex.lastIndex = 5;regex.test(str); // false (lastIndex est pris en compte avec ce marqueur)regex.lastIndex; // 0 (réinitialisation suite à l'échec)Différence entre le marqueur d'adhérence et le marqueur global
Avec le marqueur d'adhérencey, la prochaine correspondance doit être placée à la position fournie parlastIndex. En revanche, avec le marqueur globalg, la correspondance peut avoir lieu à la position indiquée parlastIndex ou après :
re = /\d/y;while ((r = re.exec("123 456"))) console.log(r, "ET re.lastIndex", re.lastIndex);// [ '1', index: 0, input: '123 456', groups: undefined ] ET re.lastIndex 1// [ '2', index: 1, input: '123 456', groups: undefined ] ET re.lastIndex 2// [ '3', index: 2, input: '123 456', groups: undefined ] ET re.lastIndex 3// ... et ensuite il n'y a plus de correspondanceAvec le marqueur globalg, les 6 chiffres auraient été trouvés (pas seulement 3).
Les expressions rationnelles et les caractères Unicode
Comme mentionné ci-avant, les classes\w ou\W ne correspondent qu'à des caractères ASCII "a" à "z", "A" à "Z", "0" à "9" et "_".
Pour effectuer des correspondances sur d'autres caractères (par exemple les caractères cyrilliques), on utilisera\uhhhh, où "hhhh" représente la valeur Unicode exprimée en hexadécimal.
Cet exemple illustre comment il est possible de séparer les caractères Unicode d'un mot.
let texte = "Образец text на русском языке";let regex = /[\u0400-\u04FF]+/g;let corresp = regex.exec(texte);console.log(corresp[0]); // affiche 'Образец'console.log(regex.lastIndex); // affiche '7'let corresp2 = regex.exec(texte);console.log(corresp2[0]); // affiche 'на' (n'affiche pas textconsole.log(regex.lastIndex); // affiche '15'// et ainsi de suiteLeséchappements de propriété Unicode, plus récents, permettent une solution plus élégante en utilisant\p{scx=Cyrl} à la place.
Extraire un sous-domaine d'une URL
let url = "http://xxx.domaine.com";console.log(/[^.]+/.exec(url)[0].substr(7)); // affiche 'xxx'Note :Cet exemple est uniquement illustratif. Pour analyser une URL, mieux vaudra utiliser les outils adaptés et notammentl'API URL.
Spécifications
| Specification |
|---|
| ECMAScript® 2026 Language Specification> # sec-regexp-regular-expression-objects> |
Compatibilité des navigateurs
Notes spécifiques à Firefox
À partir de Firefox 34, dans le cas où on utilise un groupe capturant avec des quantificateurs qui l'invalident, le texte correspondant au groupe est désormaisundefined et non la chaîne vide :
// Firefox 33 ou antérieur"x".replace(/x(.)?/g, function (m, group) { console.log("'group:" + group + "'");}); // 'group:'// Firefox 34 ou supérieur"x".replace(/x(.)?/g, function (m, group) { console.log("'group:" + group + "'");}); // 'group:undefined'Pour des raisons de compatibilité web,RegExp.$N renverra une chaîne vide au lieu deundefined (bug 1053944).
Voir aussi
- Une prothèse d'émulation pour les différentes fonctionnalités récentes des
RegExp(marqueursdotAlletsticky, groupes de capture nommés, etc.) avec la bibliothèquecore-js - Le chapitre sur les expressions rationnelles au sein duGuide JavaScript
String.prototype.match()String.prototype.replace()String.prototype.split()