Aller au contenu principal

@babel/plugin-transform-unicode-sets-regex

Traduction Bêta Non Officielle

Cette page a été traduite par PageTurner AI (bêta). Non approuvée officiellement par le projet. Vous avez trouvé une erreur ? Signaler un problème →

info

Ce plugin est inclus dans @babel/preset-env, au sein de ES2024

Ce plugin transforme les expressions régulières utilisant le flag v, introduit par la proposition RegExp set notation + properties of strings, en expressions régulières utilisant le flag u.

Il transforme uniquement la syntaxe /.../v et ne modifie pas le constructeur new RegExp, car ses arguments ne peuvent pas être pré-transformés statiquement : pour gérer le comportement dynamique des fonctions/classes, vous devrez utiliser un polyfill à la place.

Exemple

Intersection

input.js
/[\p{ASCII}&&\p{Decimal_Number}]/v;

sera transformé en

output.js
/[0-9]/u;

Différence

input.js
// Non-ASCII white spaces
/[\p{White_Space}--\p{ASCII}]/v;

sera transformé en

output.js
/[\x85\xA0\u1680\u2000-\u200A\u2028\u2029\u202F\u205F\u3000]/u;

Propriété des chaînes

input.js
/^\p{Emoji_Keycap_Sequence}$/v.test("*\uFE0F\u20E3");
// true

sera transformé en

output.js
/^(?:\*️⃣|#️⃣|0️⃣|1️⃣|2️⃣|3️⃣|4️⃣|5️⃣|6️⃣|7️⃣|8️⃣|9️⃣)$/u.test("*\uFE0F\u20E3");
// true

Voici une liste des propriétés prises en charge. Notez que l'utilisation d'une propriété de chaînes avec le flag u générera une erreur.

input.js
/\p{Emoji_Keycap_Sequence}/u;
// Error: Properties of strings are only supported when using the unicodeSets (v) flag.

Installation

npm install --save-dev @babel/plugin-transform-unicode-sets-regex

Utilisation

Avec un fichier de configuration (Recommandé)

babel.config.json
{
"plugins": ["@babel/plugin-transform-unicode-sets-regex"]
}

Via CLI

Shell
babel --plugins @babel/plugin-transform-unicode-sets-regex script.js

Via l'API Node

JavaScript
require("@babel/core").transformSync("code", {
plugins: ["@babel/plugin-transform-unicode-sets-regex"],
});