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
- "Actualizar el uso de la API useIntlayer de Solid para el acceso directo a las propiedades"v8.9.04/5/2026
- "Agregar comando init"v7.5.930/12/2025
- "Se agregó la mención de `x-default` en el objeto `alternates`"v7.0.61/11/2025
- "Historial inicial"v7.0.029/6/2025
El contenido de esta página ha sido traducido con una IA.
Ver la última versión del contenido original en inglésIf you have an idea for improving this documentation, please feel free to contribute by submitting a pull request on GitHub.
GitHub link to the documentationCopy doc Markdown to clipboard
Traduce tu sitio web Next.js 16 usando Intlayer | Internacionalización (i18n)
Consulta la Plantilla de Aplicación en GitHub.
Tabla de Contenidos
¿Por qué Intlayer en lugar de alternativas?
En comparación con soluciones principales como next-intl o i18next, Intlayer es una solución que viene con optimizaciones integradas como:
Intlayer está optimizado para funcionar con Componentes del servidor para una representación eficiente y es totalmente compatible con Turbopack. No bloquea la representación estática y ofrece middleware, así como todas las funciones necesarias para escalar la internacionalización (i18n).
Intlayer es compatible con Next.js 12, 13, 14, 15 y 16. Si está utilizando Next.js Pages Router, puede consultar esta guía. El enrutamiento por locale es útil para SEO, tamaño del bundle y rendimiento. Si no lo necesita, puede consultar esta [guía] (/es/doc/environment/nextjs/no-locale-path). Para Next.js 12, 13, 14 y 15 con App Router, consulte esta guía.
En lugar de cargar archivos JSON masivos en sus páginas, cargue solo el contenido necesario. Intlayer ayuda a reducir el tamaño de su bundle y de sus páginas hasta en un 50%.
Determinar el alcance del contenido de su aplicación facilita el mantenimiento para aplicaciones a gran escala. Puede duplicar o eliminar una sola carpeta de funciones sin la carga mental de revisar todo el código base de contenido. Además, Intlayer está completamente escrito para garantizar la precisión de su contenido.
La ubicación conjunta de contenido reduce el contexto necesario para los modelos de lenguajes grandes (LLM). Intlayer también viene con un conjunto de herramientas, como una CLI para comprobar si faltan traducciones,LSP, MCP y agent skills, para que la experiencia del desarrollador (DX) sea aún más fluida para los agentes de IA.
Utilice la automatización para traducir su canal de CI/CD utilizando el LLM de su elección al costo de su proveedor de IA. Intlayer también ofrece un compilador para automatizar la extracción de contenido, así como una plataforma web para ayudar a traducir en segundo plano.
La conexión de archivos JSON masivos a componentes puede provocar problemas de rendimiento y reactividad. Intlayer optimiza la carga de su contenido en el momento de la compilación.
Más que una simple solución i18n, Intlayer proporciona un [editor visual] autohospedado(/es/doc/concept/editor) y un CMS completo para ayudarle a administrar su contenido multilingüe en tiempo real, lo que facilita la colaboración con traductores, redactores y otros miembros del equipo. El contenido se puede almacenar de forma local y/o remota.
Guía paso a paso para configurar Intlayer en una aplicación Next.js
Instalar dependencias
Instala los paquetes necesarios usando npm:
bashCopiar códigoCopiar el código al portapapeles
npm install intlayer next-intlayernpx intlayer initintlayer
El paquete principal que proporciona herramientas de internacionalización para la gestión de configuración, traducción, declaración de contenido, transpilación y comandos CLI.
next-intlayer
El paquete que integra Intlayer con Next.js. Proporciona proveedores de contexto y hooks para la internacionalización en Next.js. Además, incluye el plugin de Next.js para integrar Intlayer con Webpack o Turbopack, así como un proxy para detectar la configuración regional preferida del usuario, gestionar cookies y manejar la redirección de URL.
Configura tu proyecto
Here is the final structure that we will make:
bashCopiar códigoCopiar el código al portapapeles
.├── src│ ├── app│ │ ├── [locale]│ │ │ ├── layout.tsx # Locale layout for the Intlayer provider│ │ │ ├── page.content.ts│ │ │ └── page.tsx│ │ └── layout.tsx # Root layout for style and global providers│ ├── components│ │ ├── client-component-example.content.ts│ │ ├── ClientComponentExample.tsx│ │ ├── LocaleSwitcher│ │ │ ├── localeSwitcher.content.ts│ │ │ └── LocaleSwitcher.tsx│ │ ├── server-component-example.content.ts│ │ └── ServerComponentExample.tsx│ └── proxy.ts├── intlayer.config.ts├── next.config.ts├── package.json└── tsconfig.jsonIf you don't want locale routing, intlayer can be used as a simple provider / hook. See this guide for more details.
Crea un archivo de configuración para configurar los idiomas de tu aplicación:
intlayer.config.tsCopiar códigoCopiar el código al portapapeles
import { Locales, type IntlayerConfig } from "intlayer"; const config: IntlayerConfig = { internationalization: { locales: [ Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH, // Tus otros locales ], defaultLocale: Locales.ENGLISH, }, }; export default config;A través de este archivo de configuración, puedes configurar URLs localizadas, redirección de proxy, nombres de cookies, la ubicación y extensión de tus declaraciones de contenido, desactivar los registros de Intlayer en la consola, y más. Para una lista completa de los parámetros disponibles, consulta la documentación de configuración.
Integra Intlayer en tu configuración de Next.js
Configura tu entorno Next.js para usar Intlayer:
next.config.tsCopiar códigoCopiar el código al portapapeles
import type { NextConfig } from "next"; import { withIntlayer } from "next-intlayer/server"; const nextConfig: NextConfig = { /* opciones de configuración aquí */ }; export default withIntlayer(nextConfig);El plugin
withIntlayer()de Next.js se utiliza para integrar Intlayer con Next.js. Garantiza la construcción de archivos de declaración de contenido y los supervisa en modo de desarrollo. Define variables de entorno de Intlayer dentro de los entornos de Webpack o Turbopack. Además, proporciona alias para optimizar el rendimiento y asegura la compatibilidad con componentes del servidor.La función
withIntlayer()es una función que devuelve una promesa. Permite preparar los diccionarios de Intlayer antes de que comience la compilación. Si deseas usarla con otros plugins, puedes usarawait. Ejemplo:tsxCopiar códigoCopiar el código al portapapeles
const nextConfig = await withIntlayer(nextConfig);const nextConfigWithOtherPlugins = withOtherPlugins(nextConfig);export default nextConfigWithOtherPlugins;Si deseas usarlo de manera sincrónica, puedes usar la función
withIntlayerSync(). Ejemplo:tsxCopiar códigoCopiar el código al portapapeles
const nextConfig = withIntlayerSync(nextConfig);const nextConfigWithOtherPlugins = withOtherPlugins(nextConfig);export default nextConfigWithOtherPlugins;Intlayer detecta automáticamente si su proyecto utiliza webpack o Turbopack según los flags de línea de comandos
--webpack,--turboo--turbopack, así como su versión actual de Next.js.Desde
next>=16, si utiliza Rspack, debe forzar explícitamente a Intlayer a usar la configuración de webpack deshabilitando Turbopack:tsCopiar códigoCopiar el código al portapapeles
withRspack(withIntlayer(nextConfig, { enableTurbopack: false }));Definir Rutas Dinámicas de Localización
Elimina todo lo que hay en
RootLayouty reemplázalo con el siguiente código:src/app/layout.tsxCopiar códigoCopiar el código al portapapeles
import type { PropsWithChildren, FC } from "react"; import "./globals.css"; const RootLayout: FC<PropsWithChildren> = ({ children }) => ( // Aún puedes envolver los children con otros proveedores, como `next-themes`, `react-query`, `framer-motion`, etc. <>{children}</> ); export default RootLayout;Mantener el componente
RootLayoutvacío permite establecer los atributoslangydiren la etiqueta<html>.Para implementar el enrutamiento dinámico, proporciona la ruta para la localización añadiendo un nuevo layout en tu directorio
[locale]:src/app/[locale]/layout.tsxCopiar códigoCopiar el código al portapapeles
import { type NextLayoutIntlayer, IntlayerClientProvider } from "next-intlayer"; import { Inter } from "next/font/google"; import { getHTMLTextDir } from "intlayer"; const inter = Inter({ subsets: ["latin"] }); const LocaleLayout: NextLayoutIntlayer = async ({ children, params }) => { const { locale } = await params; return ( <html lang={locale} dir={getHTMLTextDir(locale)}> <body className={inter.className}> <IntlayerClientProvider locale={locale}> {children} </IntlayerClientProvider> </body> </html> ); }; export default LocaleLayout;El segmento de ruta
[locale]se utiliza para definir la configuración regional. Ejemplo:/en-US/aboutse referirá aen-USy/fr/aboutafr.En esta etapa, encontrará el error:
Error: Missing <html> and <body> tags in the root layout.. Esto es esperado porque el archivo/app/page.tsxya no se utiliza y puede ser eliminado. En su lugar, el segmento de ruta[locale]activará la página/app/[locale]/page.tsx. En consecuencia, las páginas serán accesibles a través de rutas como/en,/fr,/esen su navegador. Para establecer la configuración regional predeterminada como la página raíz, consulte la configuración delproxyen el paso 7.Luego, implemente la función
generateStaticParamsen el Layout de su aplicación.src/app/[locale]/layout.tsxCopiar códigoCopiar el código al portapapeles
export { generateStaticParams } from "next-intlayer"; // Línea para insertar const LocaleLayout: NextLayoutIntlayer = async ({ children, params }) => { /*... Resto del código*/ }; export default LocaleLayout;generateStaticParamsasegura que tu aplicación preconstruya las páginas necesarias para todos los locales, reduciendo el cálculo en runtime y mejorando la experiencia del usuario. Para más detalles, consulta la documentación de Next.js sobre generateStaticParams.Intlayer funciona con
export const dynamic = 'force-static';para asegurar que las páginas se preconstruyan para todos los locales.Declara Tu Contenido
Crea y gestiona tus declaraciones de contenido para almacenar traducciones:
src/app/[locale]/page.content.tsCopiar códigoCopiar el código al portapapeles
import { t, type Dictionary } from "intlayer"; const pageContent = { key: "page", content: { getStarted: { main: t({ en: "Get started by editing", fr: "Commencez par éditer", es: "Comience por editar", }), pageLink: "src/app/page.tsx", }, }, } satisfies Dictionary; export default pageContent;Tus declaraciones de contenido pueden definirse en cualquier parte de tu aplicación siempre que estén incluidas en el directorio
contentDir(por defecto,./src). Y coincidan con la extensión de archivo de declaración de contenido (por defecto,.content.{json,ts,tsx,js,jsx,mjs,cjs,md,mdx,yaml,yml}).Para más detalles, consulta la documentación de declaración de contenido.
Utiliza el contenido en tu código
Accede a tus diccionarios de contenido en toda tu aplicación:
src/app/[locale]/page.tsxCopiar códigoCopiar el código al portapapeles
import type { FC } from "react"; import { ClientComponentExample } from "@components/ClientComponentExample"; import { ServerComponentExample } from "@components/ServerComponentExample"; import { type NextPageIntlayer } from "next-intlayer"; import { IntlayerServerProvider, useIntlayer } from "next-intlayer/server"; const PageContent: FC = () => { const content = useIntlayer("page"); return ( <> <p>{content.getStarted.main}</p> <code>{content.getStarted.pageLink}</code> </> ); }; const Page: NextPageIntlayer = async ({ params }) => { const { locale } = await params; return ( <IntlayerServerProvider locale={locale}> <PageContent /> <ServerComponentExample /> <ClientComponentExample /> </IntlayerServerProvider> ); }; export default Page;IntlayerClientProviderse utiliza para proporcionar la configuración regional a los componentes del lado del cliente. Puede colocarse en cualquier componente padre, incluido el layout. Sin embargo, se recomienda colocarlo en un layout porque Next.js comparte el código del layout entre páginas, lo que lo hace más eficiente. Al usarIntlayerClientProvideren el layout, evitas reinicializarlo para cada página, mejorando el rendimiento y manteniendo un contexto de localización consistente en toda tu aplicación.IntlayerServerProviderse utiliza para proporcionar la configuración regional a los componentes hijos del servidor. No puede establecerse en el layout.El layout y la página no pueden compartir un contexto común del servidor porque el sistema de contexto del servidor se basa en un almacén de datos por solicitud (a través del mecanismo React's cache), lo que provoca que cada "contexto" se recree para diferentes segmentos de la aplicación. Colocar el proveedor en un layout compartido rompería este aislamiento, impidiendo la correcta propagación de los valores del contexto del servidor a tus componentes del servidor.
El layout y la página no pueden compartir un contexto de servidor común porque el sistema de contexto de servidor se basa en un almacén de datos por solicitud (a través del mecanismo de caché de React), lo que provoca que cada "contexto" se vuelva a crear para diferentes segmentos de la aplicación. Colocar el proveedor en un layout compartido rompería este aislamiento, impidiendo la correcta propagación de los valores del contexto del servidor a tus componentes del servidor.
src/components/ClientComponentExample.tsxCopiar códigoCopiar el código al portapapeles
"use client"; import type { FC } from "react"; import { useIntlayer } from "next-intlayer"; export const ClientComponentExample: FC = () => { const content = useIntlayer("client-component-example"); // Crear declaración de contenido relacionada return ( <div> <h2>{content.title}</h2> <p>{content.content}</p> </div> ); };src/components/ServerComponentExample.tsxCopiar códigoCopiar el código al portapapeles
import type { FC } from "react"; import { useIntlayer } from "next-intlayer/server"; export const ServerComponentExample: FC = () => { const content = useIntlayer("server-component-example"); // Crear declaración de contenido relacionado return ( <div> <h2>{content.title}</h2> <p>{content.content}</p> </div> ); };Si quieres usar tu contenido en un atributo de tipo
string, comoalt,title,href,aria-label, etc., debes llamar al valor de la función, así:htmlCopiar códigoCopiar el código al portapapeles
<img src="{content.image.src.value}" alt="{content.image.value}" /><img src="{content.image.src.toString()}" alt="{content.image.toString()}" /><img src="{String(content.image.src)}" alt="{String(content.image)}" />Para aprender más sobre el hook
useIntlayer, consulta la documentación.Si su aplicación ya existe, puede utilizar el Compilador Intlayer, así como el comando de extracción, para transformar miles de componentes en un segundo.
Configurar Proxy para la Detección de Idioma
OpcionalConfigura un proxy para detectar el idioma preferido del usuario:
src/proxy.tsCopiar códigoCopiar el código al portapapeles
export { intlayerProxy as proxy } from "next-intlayer/proxy"; export const config = { matcher: "/((?!api|static|assets|robots|sitemap|sw|service-worker|manifest|.*\\..*|_next).*)", };El
intlayerProxyse utiliza para detectar la configuración regional preferida del usuario y redirigirlo a la URL apropiada según lo especificado en la configuración. Además, permite guardar la configuración regional preferida del usuario en una cookie.Si necesitas encadenar varios proxies juntos (por ejemplo,
intlayerProxycon autenticación o proxies personalizados), Intlayer ahora proporciona una ayuda llamadamultipleProxies.tsCopiar códigoCopiar el código al portapapeles
import { multipleProxies, intlayerProxy } from "next-intlayer/proxy";import { customProxy } from "@utils/customProxy";export const proxy = multipleProxies([intlayerProxy, customProxy]);Internacionalización de tus metadatos
OpcionalEn caso de que desees internacionalizar tus metadatos, como el título de tu página, puedes usar la función
generateMetadataproporcionada por Next.js. Dentro, puedes obtener el contenido de la funcióngetIntlayerpara traducir tus metadatos.src/app/[locale]/metadata.content.tsCopiar códigoCopiar el código al portapapeles
import { type Dictionary, t } from "intlayer"; import { Metadata } from "next"; const metadataContent = { key: "page-metadata", content: { title: t({ en: "Create Next App", fr: "Créer une application Next.js", es: "Crear una aplicación Next.js", }), description: t({ en: "Generated by create next app", fr: "Généré par create next app", es: "Generado por create next app", }), }, } satisfies Dictionary<Metadata>; export default metadataContent;src/app/[locale]/layout.tsx or src/app/[locale]/page.tsxCopiar códigoCopiar el código al portapapeles
import { getIntlayer, getMultilingualUrls } from "intlayer"; import type { Metadata } from "next"; import type { LocalPromiseParams } from "next-intlayer"; export const generateMetadata = async ({ params, }: LocalPromiseParams): Promise<Metadata> => { const { locale } = await params; const metadata = getIntlayer("page-metadata", locale); /** * Genera un objeto que contiene todas las URLs para cada idioma. * * Ejemplo: * ```ts * getMultilingualUrls('/about'); * * // Devuelve * // { * // en: '/about', * // fr: '/fr/about', * // es: '/es/about', * // } * ``` */ const multilingualUrls = getMultilingualUrls("/"); const localizedUrl = multilingualUrls[locale as keyof typeof multilingualUrls]; return { ...metadata, alternates: { canonical: localizedUrl, languages: { ...multilingualUrls, "x-default": "/" }, }, openGraph: { url: localizedUrl, }, }; }; // ... Resto del códigoTenga en cuenta que la función
getIntlayerimportada desdenext-intlayerdevuelve su contenido envuelto en unIntlayerNode, lo que permite la integración con el editor visual. En cambio, la funcióngetIntlayerimportada desdeintlayerdevuelve su contenido directamente sin propiedades adicionales.Alternativamente, puedes usar la función
getTranslationpara declarar tus metadatos. Sin embargo, se recomienda usar archivos de declaración de contenido para automatizar la traducción de tus metadatos y externalizar el contenido en algún momento.src/app/[locale]/layout.tsx or src/app/[locale]/page.tsxCopiar códigoCopiar el código al portapapeles
import { type IConfigLocales, getTranslation, getMultilingualUrls, } from "intlayer"; import type { Metadata } from "next"; import type { LocalPromiseParams } from "next-intlayer"; export const generateMetadata = async ({ params, }: LocalPromiseParams): Promise<Metadata> => { const { locale } = await params; const t = <T>(content: IConfigLocales<T>) => getTranslation(content, locale); return { title: t<string>({ en: "My title", Alternativamente, puedes usar la función `getTranslation` para declarar tus metadatos. Sin embargo, se recomienda usar archivos de declaración de contenido para automatizar la traducción de tus metadatos y externalizar el contenido en algún momento. ```typescript fileName="src/app/[locale]/layout.tsx or src/app/[locale]/page.tsx" codeFormat="typescript" import { type IConfigLocales, getTranslation, getMultilingualUrls, } from "intlayer"; import type { Metadata } from "next"; import type { LocalPromiseParams } from "next-intlayer"; export const generateMetadata = async ({ params, }: LocalPromiseParams): Promise<Metadata> => { const { locale } = await params; const t = <T>(content: IConfigLocales<T>) => getTranslation(content, locale); return { title: t<string>({ en: "My title", fr: "Mon titre", es: "Mi título", }), description: t({ en: "My description", fr: "Ma description", es: "Mi descripción", }), }; }; // ... Resto del códigoAprende más sobre la optimización de metadatos en la documentación oficial de Next.js.
plaintextCopiar códigoCopiar el código al portapapeles
```javascript fileName="src/app/[locale]/layout.cjs or src/app/[locale]/page.cjs" codeFormat="commonjs"const { getTranslation, getMultilingualUrls } = require("intlayer");const generateMetadata = async ({ params }) => { const { locale } = await params; const t = (content) => getTranslation(content, locale); return { title: t({ en: "My title", fr: "Mon titre", es: "Mi título", }), description: t({ en: "My description", fr: "Ma description", es: "Mi descripción", }), };};module.exports = { generateMetadata };// ... Resto del códigoAprende más sobre la optimización de metadatos en la documentación oficial de Next.js.
Internacionalización de tu sitemap.xml y robots.txt
OpcionalPara internacionalizar tu
sitemap.xmlyrobots.txt, puedes usar la funcióngetMultilingualUrlsproporcionada por Intlayer. Esta función te permite generar URLs multilingües para tu sitemap.src/app/sitemap.tsCopiar códigoCopiar el código al portapapeles
import { getMultilingualUrls } from "intlayer"; import type { MetadataRoute } from "next"; const sitemap = (): MetadataRoute.Sitemap => [ { url: "https://example.com", alternates: { languages: { ...getMultilingualUrls("https://example.com"), "x-default": "https://example.com", }, }, }, { url: "https://example.com/login", alternates: { languages: { ...getMultilingualUrls("https://example.com/login"), "x-default": "https://example.com/login", }, }, }, { url: "https://example.com/register", alternates: { languages: { ...getMultilingualUrls("https://example.com/register"), "x-default": "https://example.com/register", }, }, }, ]; export default sitemap;src/app/robots.tsCopiar códigoCopiar el código al portapapeles
import type { MetadataRoute } from "next"; import { getMultilingualUrls } from "intlayer"; const getAllMultilingualUrls = (urls: string[]) => urls.flatMap((url) => Object.values(getMultilingualUrls(url)) as string[]); // Configuración de reglas para robots.txt const robots = (): MetadataRoute.Robots => ({ rules: { userAgent: "*", // Aplica a todos los agentes de usuario allow: ["/"], // Permite acceso a la raíz disallow: getAllMultilingualUrls(["/login", "/register"]), // Bloquea URLs multilingües de login y registro }, host: "https://example.com", sitemap: `https://example.com/sitemap.xml`, }); export default robots;Aprende más sobre la optimización del sitemap en la documentación oficial de Next.js. Aprende más sobre la optimización del archivo robots.txt en la documentación oficial de Next.js.
Cambia el idioma de tu contenido
OpcionalPara cambiar el idioma de tu contenido en Next.js, la forma recomendada es usar el componente
Linkpara redirigir a los usuarios a la página localizada correspondiente. El componenteLinkpermite la precarga de la página, lo que ayuda a evitar una recarga completa de la página.src/components/LocaleSwitcher.tsxCopiar códigoCopiar el código al portapapeles
"use client"; import type { FC } from "react"; import { Locales, getHTMLTextDir, getLocaleName, getLocalizedUrl, } from "intlayer"; import { useLocale } from "next-intlayer"; import Link from "next/link"; export const LocaleSwitcher: FC = () => { const { locale, pathWithoutLocale, availableLocales, setLocale } = useLocale(); return ( <div> <button popoverTarget="localePopover">{getLocaleName(locale)}</button> <div id="localePopover" popover="auto"> {availableLocales.map((localeItem) => ( <Link href={getLocalizedUrl(pathWithoutLocale, localeItem)} key={localeItem} aria-current={locale === localeItem ? "page" : undefined} onClick={() => setLocale(localeItem)} replace // Esto asegurará que el botón "volver" del navegador redirija a la página anterior > <span> {/* Local - p. ej., FR */} {localeItem} </span> <span> {/* Idioma en su propia localización - p. ej., Français */} {getLocaleName(localeItem, locale)} </span> <span dir={getHTMLTextDir(localeItem)} lang={localeItem}> {/* Idioma en la localización actual - p. ej., Francés con la localización actual configurada en Locales.SPANISH */} {getLocaleName(localeItem)} </span> <span dir="ltr" lang={Locales.ENGLISH}> {/* Idioma en inglés - p. ej., French */} {getLocaleName(localeItem, Locales.ENGLISH)} </span> </Link> ))} </div> </div> ); };Una forma alternativa es usar la función
setLocaleproporcionada por el hookuseLocale. Esta función no permitirá la precarga de la página. Consulta la documentación del hookuseLocalepara más detalles.También puedes establecer una función en la opción
onLocaleChangepara activar una función personalizada cuando cambie la configuración regional.src/components/LocaleSwitcher.tsxCopiar códigoCopiar el código al portapapeles
"use client";import { useRouter } from "next/navigation";import { useLocale } from "next-intlayer";import { getLocalizedUrl } from "intlayer";// ... Resto del códigoconst router = useRouter();const { setLocale } = useLocale({ onLocaleChange: (locale) => { router.push(getLocalizedUrl(pathWithoutLocale, locale)); },});return ( <button onClick={() => setLocale(Locales.FRENCH)}>Cambiar a francés</button>);Referencias de la documentación:
Creación de un Componente de Enlace Localizado
OpcionalPara asegurar que la navegación de tu aplicación respete la configuración regional actual, puedes crear un componente personalizado
Link. Este componente antepone automáticamente a las URLs internas el idioma actual. Por ejemplo, cuando un usuario francófono hace clic en un enlace a la página "Acerca de", es redirigido a/fr/abouten lugar de/about.Este comportamiento es útil por varias razones:
- SEO y experiencia del usuario: Las URLs localizadas ayudan a los motores de búsqueda a indexar correctamente las páginas específicas por idioma y proporcionan a los usuarios contenido en su idioma preferido.
- Consistencia: Al usar un enlace localizado en toda tu aplicación, garantizas que la navegación se mantenga dentro de la configuración regional actual, evitando cambios inesperados de idioma.
- Mantenibilidad: Centralizar la lógica de localización en un solo componente simplifica la gestión de URLs, haciendo que tu base de código sea más fácil de mantener y ampliar a medida que tu aplicación crece.
A continuación se muestra la implementación de un componente
Linklocalizado en TypeScript:src/components/Link.tsxCopiar códigoCopiar el código al portapapeles
"use client"; import { getLocalizedUrl } from "intlayer"; import NextLink, { type LinkProps as NextLinkProps } from "next/link"; import { useLocale } from "next-intlayer"; import type { PropsWithChildren, FC } from "react"; /** * Función utilitaria para verificar si una URL dada es externa. * Si la URL comienza con http:// o https://, se considera externa. */ export const checkIsExternalLink = (href?: string): boolean => /^https?:\/\//.test(href ?? ""); /** * Un componente Link personalizado que adapta el atributo href según la configuración regional actual. * Para enlaces internos, utiliza `getLocalizedUrl` para anteponer la configuración regional a la URL (por ejemplo, /fr/about). * Esto asegura que la navegación se mantenga dentro del mismo contexto regional. */ export const Link: FC<PropsWithChildren<NextLinkProps>> = ({ href, children, ...props }) => { const { locale } = useLocale(); const isExternalLink = checkIsExternalLink(href.toString()); // Si el enlace es interno y se proporciona un href válido, obtiene la URL localizada. const hrefI18n: NextLinkProps["href"] = href && !isExternalLink ? getLocalizedUrl(href.toString(), locale) : href; return ( <NextLink href={hrefI18n} {...props}> {children} </NextLink> ); };Cómo Funciona
Detección de Enlaces Externos:
La función auxiliarcheckIsExternalLinkdetermina si una URL es externa. Los enlaces externos se dejan sin cambios porque no necesitan localización.Recuperar la configuración regional actual:
El hookuseLocaleproporciona la configuración regional actual (por ejemplo,frpara francés).Localizar la URL:
Para enlaces internos (es decir, no externos), se utilizagetLocalizedUrlpara prefijar automáticamente la URL con la configuración regional actual. Esto significa que si tu usuario está en francés, pasar/aboutcomohrefse transformará en/fr/about.Devolver el enlace:
El componente devuelve un elemento<a>con la URL localizada, asegurando que la navegación sea coherente con la configuración regional.
Al integrar este componente
Linken toda su aplicación, mantiene una experiencia de usuario coherente y consciente del idioma, al mismo tiempo que se beneficia de una mejor SEO y usabilidad.Obtener la configuración regional actual en las Acciones del Servidor
OpcionalSi necesita la configuración regional activa dentro de una Acción del Servidor (por ejemplo, para localizar correos electrónicos o ejecutar lógica dependiente del idioma), llame a
getLocaledesdenext-intlayer/server:src/app/actions/getLocale.tsCopiar códigoCopiar el código al portapapeles
"use server";import { getLocale } from "next-intlayer/server";export const myServerAction = async () => { const locale = await getLocale(); // Hacer algo con la configuración regional};La función
getLocalesigue una estrategia en cascada para determinar la configuración regional del usuario:- Primero, verifica en los encabezados de la solicitud si hay un valor de configuración regional que pueda haber sido establecido por el proxy
- Si no se encuentra una configuración regional en los encabezados, busca una configuración regional almacenada en las cookies
- Si no se encuentra ninguna cookie, intenta detectar el idioma preferido del usuario a partir de la configuración de su navegador
- Como último recurso, utiliza la configuración regional predeterminada configurada en la aplicación
Esto asegura que se seleccione la configuración regional más apropiada según el contexto disponible.
Optimiza el tamaño de tu paquete
OpcionalAl usar
next-intlayer, los diccionarios se incluyen en el paquete para cada página por defecto. Para optimizar el tamaño del bundle, Intlayer proporciona un plugin SWC opcional que reemplaza inteligentemente las llamadas auseIntlayerusando macros. Esto asegura que los diccionarios solo se incluyan en los paquetes de las páginas que realmente los usan.Para habilitar esta optimización, instala el paquete
@intlayer/swc. Una vez instalado,next-intlayerdetectará y usará automáticamente el plugin:bashCopiar códigoCopiar el código al portapapeles
npm install @intlayer/swc --save-devNota: Esta optimización solo está disponible para Next.js 13 y versiones superiores.
Nota: Este paquete no se instala por defecto porque los plugins SWC aún son experimentales en Next.js. Esto podría cambiar en el futuro.
Nota: Si establece la opción como
importMode: 'dynamic'oimportMode: 'fetch'(en la configuración del diccionario), dependerá de Suspense, por lo que tendrá que envolver sus llamadas auseIntlayeren un límite deSuspense. Eso significa que no podrá usaruseIntlayerdirectamente en el nivel superior de su componente Página / Layout.Extraer el contenido de tus componentes
OpcionalSi tienes una base de código existente, transformar miles de archivos puede llevar mucho tiempo.
Para facilitar este proceso, Intlayer propone un compilador / extractor para transformar tus componentes y extraer el contenido.
Para configurarlo, puedes agregar una sección
compileren tu archivointlayer.config.ts:intlayer.config.tsCopiar códigoCopiar el código al portapapeles
import { type IntlayerConfig } from "intlayer"; const config: IntlayerConfig = { // ... Resto de tu configuración compiler: { /** * Indica si el compilador debe estar habilitado. */ enabled: true, /** * Define la ruta de los archivos de salida */ output: ({ fileName, extension }) => `./${fileName}${extension}`, /** * Indica si los componentes deben guardarse después de ser transformados. De esa manera, el compilador se puede ejecutar solo una vez para transformar la aplicación y luego se puede eliminar. */ saveComponents: false, /** * Prefijo de clave de diccionario */ dictionaryKeyPrefix: "", }, }; export default config;Ejecuta el extractor para transformar tus componentes y extraer el contenido
bashCopiar códigoCopiar el código al portapapeles
npx intlayer extract
Supervisar cambios en los diccionarios con Turbopack
Cuando se usa Turbopack como servidor de desarrollo con el comando next dev, los cambios en los diccionarios no se detectan automáticamente por defecto.
Esta limitación ocurre porque Turbopack no puede ejecutar plugins de webpack en paralelo para monitorear cambios en tus archivos de contenido. Para solucionar esto, necesitarás usar el comando intlayer watch para ejecutar simultáneamente el servidor de desarrollo y el observador de compilación de Intlayer.
Copiar el código al portapapeles
{ // ... Tus configuraciones existentes en package.json "scripts": { // ... Tus configuraciones existentes de scripts "dev": "intlayer watch --with 'next dev'", },}Si estás usando next-intlayer@<=6.x.x, necesitas mantener el flag --turbopack para que la aplicación Next.js 16 funcione correctamente con Turbopack. Recomendamos usar next-intlayer@>=7.x.x para evitar esta limitación.
Configurar TypeScript
Intlayer usa la ampliación de módulos para aprovechar las ventajas de TypeScript y fortalecer tu base de código.


Asegúrate de que tu configuración de TypeScript incluya los tipos autogenerados.
Copiar el código al portapapeles
{ // ... Tus configuraciones existentes de TypeScript "include": [ // ... Tus configuraciones existentes de TypeScript ".intlayer/**/*.ts", // Include the auto-generated types ],}Configuración de Git
Se recomienda ignorar los archivos generados por Intlayer. Esto te permite evitar comprometerlos en tu repositorio Git.
Para hacerlo, puedes agregar las siguientes instrucciones a tu archivo .gitignore:
Copiar el código al portapapeles
# Ignorar los archivos generados por Intlayer.intlayerExtensión para VS Code
Para mejorar tu experiencia de desarrollo con Intlayer, puedes instalar la Extensión oficial de Intlayer para VS Code.
Instalar desde el Marketplace de VS Code
Esta extensión proporciona:
- Autocompletado para las claves de traducción.
- Detección de errores en tiempo real para traducciones faltantes.
- Vistas previas en línea del contenido traducido.
- Acciones rápidas para crear y actualizar traducciones fácilmente.
Para más detalles sobre cómo usar la extensión, consulta la documentación de la extensión Intlayer para VS Code.
Ir más allá
Para ir más allá, puedes implementar el editor visual o externalizar tu contenido usando el CMS.