Haz tu pregunta y obtén un resumen del documento referenciando esta página y el proveedor AI de tu elección
Al integrar el servidor MCP Intlayer a tu asistente de IA, puedes recuperar todos los documentos directamente desde ChatGPT, DeepSeek, Cursor, VSCode, etc.
Ver la documentación del servidor MCPHistorial de versiones
- Lanzamiento del Compilerv7.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 transform (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
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 ],});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:
# Para Vuenpm install @intlayer/vue-compiler# Para Sveltenpm install @intlayer/svelte-compilerNext.js (Babel)
Para Next.js u otras aplicaciones basadas en Webpack que usan Babel, puedes configurar el compilador usando el plugin @intlayer/babel.
Instalación
npm install @intlayer/babelConfiguración
Actualiza tu babel.config.js (o babel.config.json) para incluir el plugin de extracción. Proporcionamos un helper getExtractPluginOptions para cargar automáticamente tu configuración de Intlayer.
Copiar el código al portapapeles
const { intlayerExtractBabelPlugin, intlayerOptimizeBabelPlugin, getExtractPluginOptions, getOptimizePluginOptions,} = require("@intlayer/babel");module.exports = { presets: ["next/babel"], plugins: [ // Extract content from components into dictionaries [intlayerExtractBabelPlugin, getExtractPluginOptions()], // Optimize imports by replacing useIntlayer with direct dictionary imports [intlayerOptimizeBabelPlugin, getOptimizePluginOptions()], ],};Esta configuración asegura que el contenido declarado en tus componentes se extraiga automáticamente y se utilice para generar diccionarios durante tu proceso de compilación.