Haz tu pregunta y obtén un resumen del documento referenciando esta página y el proveedor AI de tu elección
Historial de versiones
- "Update compiler options, add FilePathPattern support"v8.2.010/3/2026
- "Actualizar opciones del compilador"v8.1.725/2/2026
- "Lanzamiento del Compiler"v7.3.127/11/2025
El contenido de esta página ha sido traducido con una IA.
Ver la última versión del contenido original en inglésSi tienes una idea para mejorar esta documentación, no dudes en contribuir enviando una pull request en GitHub.
Enlace de GitHub a la documentaciónCopiar el Markdown del documento a la portapapeles
Intlayer Compiler | Extracción Automática de Contenido para i18n
¿Qué es el Intlayer Compiler?
El Intlayer Compiler es una herramienta poderosa diseñada para automatizar el proceso de internacionalización (i18n) en tus aplicaciones. Escanea tu código fuente (JSX, TSX, Vue, Svelte) en busca de declaraciones de contenido, las extrae y genera automáticamente los archivos de diccionario necesarios. Esto te permite mantener tu contenido junto a tus componentes mientras Intlayer se encarga de la gestión y sincronización de tus diccionarios.
¿Por qué usar el Intlayer Compiler?
- Automatización: Elimina el copiado manual de contenido en los diccionarios.
- Velocidad: Extracción de contenido optimizada que asegura que tu proceso de build siga siendo rápido.
- Experiencia del desarrollador: Mantén las declaraciones de contenido justo donde se usan, mejorando la mantenibilidad.
- Actualizaciones en vivo: Soporta Hot Module Replacement (HMR) para retroalimentación instantánea durante el desarrollo.
Consulta el artículo del blog Compiler vs. Declarative i18n para una comparación más profunda.
¿Por qué no usar el Intlayer Compiler?
Si bien el compilador ofrece una excelente experiencia de "funciona sin más", también introduce algunos compromisos de los que debes ser consciente:
- Ambigüedad heurística: El compilador debe adivinar qué es contenido orientado al usuario frente a la lógica de la aplicación (por ejemplo,
className="active", códigos de estado, IDs de productos). En bases de código complejas, esto puede llevar a falsos positivos o cadenas omitidas que requieren anotaciones manuales y excepciones. - Extracción solo estática: La extracción basada en compilador se basa en análisis estático. Las cadenas que solo existen en tiempo de ejecución (códigos de error de API, campos CMS, etc.) no pueden ser descubiertas o traducidas por el compilador solo, por lo que aún necesitas una estrategia i18n de tiempo de ejecución complementaria.
Para una comparación arquitectónica más profunda, consulta el artículo del blog Compiler vs. Declarative i18n.
Como alternativa, para automatizar tu proceso i18n mientras mantienes el control total de tu contenido, Intlayer también proporciona un comando de auto-extracción intlayer extract (consulta la documentación CLI), o el comando Intlayer: extract content to Dictionary de la extensión Intlayer VS Code (consulta la documentación de la extensión VS Code).
Uso
Vite
Para aplicaciones basadas en Vite (React, Vue, Svelte, etc.), la forma más sencilla de usar el compilador es a través del plugin vite-intlayer.
Instalación
Copiar el código al portapapeles
npm install vite-intlayerConfiguración
Actualiza tu vite.config.ts para incluir el plugin intlayerCompiler:
Copiar el código al portapapeles
import { defineConfig } from "vite";import { intlayer, intlayerCompiler } from "vite-intlayer";export default defineConfig({ plugins: [ intlayer(), intlayerCompiler(), // Añade el plugin del compilador ],});See complete tutorial: Intlayer Compiler with Vite+React
Soporte de Framework
El plugin de Vite detecta y maneja automáticamente diferentes tipos de archivos:
- React / JSX / TSX: Manejado de forma nativa.
- Vue: Requiere
@intlayer/vue-compiler. - Svelte: Requiere
@intlayer/svelte-compiler.
Asegúrate de instalar el paquete de compilador adecuado para tu framework:
Copiar el código al portapapeles
# Para Vuenpm install @intlayer/vue-compiler# Para Sveltenpm install @intlayer/svelte-compilerConfiguración personalizada
Para personalizar el comportamiento del compilador, puedes actualizar el archivo intlayer.config.ts en la raíz de tu proyecto.
Copiar el código al portapapeles
import { type IntlayerConfig, Locales } from "intlayer";const config: IntlayerConfig = { compiler: { /** * Indica si el compilador debe estar habilitado. * Establécelo en 'build-only' para omitir el compilador durante el desarrollo y acelerar los tiempos de inicio. */ enabled: true, /** * Define la ruta de los archivos de salida. Reemplaza `outputDir`. * * - Las rutas `./` se resuelven de forma relativa al directorio del componente. * - Las rutas `/` se resuelven de forma relativa a la raíz del proyecto (`baseDir`). * * - Incluir la variable `{{locale}}` en la ruta activará la generación de diccionarios separados por locale. * * Ejemplo: * ```ts * { * // Crear archivos .content.ts multilingües cerca del componente * output: ({ fileName, extension }) => `./${fileName}${extension}`, * * // output: './{{fileName}}{{extension}}', // Equivalente usando una cadena de plantilla * } * ``` * * ```ts * { * // Crear JSON centralizados por locale en la raíz del proyecto * output: ({ key, locale }) => `/locales/${locale}/${key}.content.json`, * * // output: '/locales/{{locale}}/{{key}}.content.json', // Equivalente usando una cadena de plantilla * } * ``` * * Lista de variables: * - `fileName`: El nombre del archivo. * - `key`: La clave del contenido. * - `locale`: El locale del contenido. * - `extension`: La extensión del archivo. * - `componentFileName`: El nombre del archivo del componente. * - `componentExtension`: La extensión del archivo del componente. * - `format`: El formato del diccionario. * - `componentFormat`: El formato del diccionario del componente. * - `componentDirPath`: La ruta del directorio del componente. */ output: ({ fileName, extension }) => `./${fileName}${extension}`, /** * Indica si los componentes deben guardarse después de ser transformados. * * - Si es `true`, el compilador reescribirá el archivo del componente en el disco. Por lo tanto, la transformación será permanente y el compilador omitirá la transformación en el próximo proceso. De esta manera, el compilador puede transformar la aplicación y luego puede ser eliminado. * * - Si es `false`, el compilador inyectará la llamada a la función `useIntlayer()` en el código solo en la salida del build, y mantendrá intacta la base de código original. La transformación se realizará solo en memoria. */ saveComponents: false, /** * Insertar solo contenido en el archivo generado, útil para salidas JSON de i18next o ICU MessageFormat por locale. * * - `output: ({ locale, key }) => `./locale/${locale}/${key}.json`,` */ noMetadata: false, /** * Prefijo de clave de diccionario */ dictionaryKeyPrefix: "", // Añadir un prefijo opcional para las claves de diccionario extraídas },};export default config;Referencia de configuración del compilador
Las siguientes propiedades pueden configurarse en el bloque compiler de tu archivo intlayer.config.ts:
enabled:
- Tipo:
boolean | 'build-only' - Por defecto:
true - Descripción: Indica si el compilador debe estar habilitado.
- Tipo:
dictionaryKeyPrefix:
- Tipo:
string - Por defecto:
'' - Descripción: Prefijo para las claves de diccionario extraídas.
- Tipo:
transformPattern:
- Tipo:
string | string[] - Por defecto:
['**/*.{js,ts,mjs,cjs,jsx,tsx,vue,svelte}', '!**/node_modules/**'] - Descripción: (Obsoleto: usa
build.traversePatternen su lugar) Patrones para recorrer el código a optimizar.
- Tipo:
excludePattern:
- Tipo:
string | string[] - Por defecto:
['**/node_modules/**'] - Descripción: (Obsoleto: usa
build.traversePatternen su lugar) Patrones para excluir de la optimización.
- Tipo:
output:
- Tipo:
FilePathPattern - Por defecto:
({ key }) => 'compiler/${key}.content.json' - Descripción: Define la ruta de los archivos de salida. Reemplaza
outputDir. Maneja variables dinámicas como{{locale}},{{key}},{{fileName}},{{extension}},{{format}},{{dirPath}},{{componentFileName}},{{componentExtension}},{{componentFormat}}. Se puede configurar como una cadena usando el formato'my/{{var}}/path'o como una función. - Nota:
./**/*Las rutas se resuelven de forma relativa al componente./**/*las rutas se resuelven de forma relativa albaseDirde Intlayer. - Note: Si el locale se establece en la ruta, generará diccionarios por locale.
- Ejemplo:
output: ({ locale, key }) => 'compiler/${locale}/${key}.json'
- Tipo:
noMetadata:
- Tipo:
boolean - Por defecto:
false - Descripción: Indica si los metadatos deben guardarse en el archivo. Si es verdadero, el compilador no guardará los metadatos de los diccionarios (clave, contenedor de contenido). Útil para las salidas JSON de i18next o ICU MessageFormat por locale.
- Nota: Útil si se usa con el plugin
loadJSON. - Ejemplo:
Si es
true:json { "key": "value" }Si esfalse:json { "key": "value", "content": { "key": "value" } }
- Tipo:
saveComponents:
- Tipo:
boolean - Por defecto:
false - Descripción: Indica si los componentes deben guardarse después de ser transformados.
- Si es
true, el compilador reescribirá el archivo del componente en el disco. La transformación será permanente y el compilador podrá ser eliminado. - Si es
false, el compilador inyectará la llamada a la funciónuseIntlayer()en el código solo en la salida del build, y mantendrá intacta la base de código original. La transformación se realizará solo en memoria.
- Si es
- Tipo:
Rellenar traducciones faltantes
Intlayer proporciona una herramienta CLI para ayudarte a rellenar las traducciones faltantes. Puedes usar el comando intlayer para probar y rellenar las traducciones faltantes de tu código.
Copiar el código al portapapeles
npx intlayer test # Probar si faltan traduccionesCopiar el código al portapapeles
npx intlayer fill # Rellenar traducciones faltantesExtracción
Intlayer proporciona una herramienta CLI para extraer contenido de tu código. Puedes usar el comando intlayer extract para extraer contenido de tu código.
Copiar el código al portapapeles
npx intlayer extractPara más detalles, consulta la documentación de la CLI