Saltar al contenido principal

@babel/plugin-transform-regexp-modifiers

Traducción Beta No Oficial

Esta página fue traducida por PageTurner AI (beta). No está respaldada oficialmente por el proyecto. ¿Encontraste un error? Reportar problema →

información

Este plugin está incluido en @babel/preset-env, específicamente en ES2025.

Ejemplo

Modificador i

input.js
// matches Aa and aa
const regex = /(?i:a)a/

se transformará en

output.js
const regex = /(?:[Aa])a/

Modificador m

input.js
// matches aa, a\naa, etc. but not a\na
const regex = /(?m:^a)a/

se transformará en

output.js
const regex = /(?:(?:^|(?<=[\n\r\u2028\u2029]))a)a/

Modificador s

input.js
// matches \na and aa, but not \n\n
const regex = /(?s:.)./

se transformará en

output.js
const regex = /(?:[\s\S])./;

Múltiples modificadores

También puedes habilitar múltiples modificadores:

// matches Aa, aa, A\naa, etc. but not A\na
const regex = /(?im:^a)a/

o deshabilitarlos:

// matches Aa, aa, A\naa, etc. but not A\na
const regex = /^a(?-im:a)/im

Esta propuesta solo admite i, m y s como modificadores en línea.

Instalación

npm install --save-dev @babel/plugin-transform-regexp-modifiers

Uso

Mediante un archivo de configuración (Recomendado)

babel.config.json
{
"plugins": ["@babel/plugin-transform-regexp-modifiers"]
}

Mediante la CLI

Shell
babel --plugins @babel/@babel/plugin-transform-regexp-modifiers script.js

Mediante la API de Node.js

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

Referencias