Pose una domanda e ottieni un riassunto del documento facendo riferimento a questa pagina e al provider AI di tua scelta
Cronologia delle versioni
- "Aggiornare l'uso dell'API useIntlayer di Solid all'accesso diretto alle proprietà"v8.9.004/05/2026
Il contenuto di questa pagina è stato tradotto con un'IA.
Vedi l'ultima versione del contenuto originale in ingleseIf 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
Traduci la tua Next.js 14 and App Router con Intlayer | Internazionalizzazione (i18n)
Consulta Application Template su GitHub.
Perché Intlayer rispetto alle alternative?
Rispetto alle soluzioni principali come next-intl o i18next, Intlayer è una soluzione dotata di ottimizzazioni integrate come:
Intlayer è ottimizzato per funzionare con Componenti server per un rendering efficiente ed è completamente compatibile con Turbopack. Non blocca il rendering statico e offre middleware e tutte le funzionalità necessarie per scalare l'internazionalizzazione (i18n).
Intlayer è compatibile con Next.js 12, 13, 14, 15 e 16. Se stai utilizzando Next.js Pages Router, puoi fare riferimento a questa guida. Il routing per locale è utile per SEO, dimensioni del pacchetto e prestazioni. Se non ti serve, puoi fare riferimento a questa guida. Per Next.js 12, 13, 14 e 15 con App Router, fare riferimento a questa guida.
Invece di caricare enormi file JSON nelle tue pagine, carica solo il contenuto necessario. Intlayer aiuta a ridurre le dimensioni del bundle e della pagina fino al 50%.
L'ambito del contenuto dell'applicazione facilita la manutenzione per applicazioni su larga scala. Puoi duplicare o eliminare una singola cartella di funzionalità senza l'onere mentale di rivedere l'intera codebase dei contenuti. Inoltre, Intlayer è completamente tipizzato (fully typed) per garantire l'accuratezza dei tuoi contenuti.
La co-localizzazione dei contenuti riduce il contesto necessario dai Large Language Models (LLM). Intlayer viene fornito anche con una suite di strumenti, come una CLI per verificare le traduzioni mancanti,LSP, MCP e capacità dell'agente, per rendere l'esperienza dello sviluppatore (DX) ancora più fluida per gli agenti IA.
Utilizza l'automazione per tradurre nella tua pipeline CI/CD utilizzando il LLM di tua scelta al costo del tuo provider di intelligenza artificiale. Intlayer offre anche un compilatore per automatizzare l'estrazione dei contenuti, nonché una piattaforma web per aiutare a tradurre in background.
La connessione di enormi file JSON ai componenti può portare a problemi di prestazioni e reattività. Intlayer ottimizza il caricamento dei contenuti in fase di compilazione.
Più di una semplice soluzione i18n, Intlayer fornisce un editor visivo self-hosted e un CMS completo per aiutarti gestisci i tuoi contenuti multilingue in tempo reale, semplificando la collaborazione con traduttori, copywriter e altri membri del team. I contenuti possono essere archiviati localmente e/o in remoto.
Guida passo-passo per configurare Intlayer in un'applicazione Next.js
Installa le dipendenze
Installa i pacchetti necessari utilizzando npm:
bashCopiare il codiceCopiare il codice nella clipboard
npm install intlayer next-intlayernpx intlayer initintlayer
Il pacchetto principale che fornisce strumenti di internazionalizzazione per la gestione della configurazione, traduzione, dichiarazione dei contenuti, transpilation e comandi CLI.
next-intlayer
Il pacchetto che integra Intlayer con Next.js. Fornisce provider di contesto e hook per l'internazionalizzazione di Next.js. Inoltre, include il plugin Next.js per integrare Intlayer con Webpack o Turbopack, oltre a middleware per rilevare la lingua preferita dell'utente, gestire i cookie e gestire i reindirizzamenti URL.
Configura il tuo progetto
Here is the final structure that we will make:
bashCopiare il codiceCopiare il codice nella clipboard
.├── 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│ └── middleware.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 file di configurazione per configurare le lingue della tua applicazione:
intlayer.config.tsCopiare il codiceCopiare il codice nella clipboard
import { Locales, type IntlayerConfig } from "intlayer"; const config: IntlayerConfig = { internationalization: { locales: [ Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH, // Le tue altre lingue ], defaultLocale: Locales.ENGLISH, }, }; export default config;Tramite questo file di configurazione, puoi configurare URL localizzati, reindirizzamenti middleware, nomi dei cookie, la posizione e l'estensione delle dichiarazioni dei contenuti, disabilitare i log di Intlayer nella console e altro ancora. Per un elenco completo dei parametri disponibili, consulta la documentazione di configurazione.
Integra Intlayer nella configurazione di Next.js
Configura il tuo setup Next.js per utilizzare Intlayer:
next.config.mjsCopiare il codiceCopiare il codice nella clipboard
import { withIntlayer } from "next-intlayer/server";/** @type {import('next').NextConfig} */const nextConfig = {};export default withIntlayer(nextConfig);Il plugin
withIntlayer()di Next.js è utilizzato per integrare Intlayer con Next.js. Garantisce la costruzione dei file di dichiarazione dei contenuti e li monitora in modalità di sviluppo. Definisce le variabili di ambiente di Intlayer all'interno degli ambienti Webpack o Turbopack. Inoltre, fornisce alias per ottimizzare le prestazioni e garantisce la compatibilità con i componenti server.Configura il Middleware per il rilevamento della lingua
Configura il middleware per rilevare la lingua preferita dell'utente:
src/middleware.tsCopiare il codiceCopiare il codice nella clipboard
export { intlayerMiddleware as middleware } from "next-intlayer/middleware"; export const config = { matcher: "/((?!api|static|assets|robots|sitemap|sw|service-worker|manifest|.*\\..*|_next).*)", };Il
intlayerMiddlewareè utilizzato per rilevare la lingua preferita dell'utente e reindirizzarlo all'URL appropriato come specificato nella configurazione. Inoltre, consente di salvare la lingua preferita dell'utente in un cookie.Adatta il parametro
matcherper corrispondere alle rotte della tua applicazione. Per maggiori dettagli, consulta la documentazione di Next.js sulla configurazione del matcher.Definisci rotte dinamiche per la lingua
Rimuovi tutto da
RootLayoute sostituiscilo con il seguente codice:src/app/layout.tsxCopiare il codiceCopiare il codice nella clipboard
import type { PropsWithChildren, FC } from "react"; import "./globals.css"; const RootLayout: FC<PropsWithChildren> = ({ children }) => children; export default RootLayout;Mantenere il componente
RootLayoutvuoto consente di impostare gli attributilangedirnel tag<html>.Per implementare il routing dinamico, fornisci il percorso per la lingua aggiungendo un nuovo layout nella tua directory
[locale]:src/app/[locale]/layout.tsxCopiare il codiceCopiare il codice nella clipboard
import { type Next14LayoutIntlayer, IntlayerClientProvider, } from "next-intlayer"; import { Inter } from "next/font/google"; import { getHTMLTextDir } from "intlayer"; const inter = Inter({ subsets: ["latin"] }); const LocaleLayout: Next14LayoutIntlayer = ({ children, params: { locale }, }) => ( <html lang={locale} dir={getHTMLTextDir(locale)}> <body className={inter.className}> <IntlayerClientProvider locale={locale}> {children} </IntlayerClientProvider> </body> </html> ); export default LocaleLayout;Il segmento di percorso
[locale]è utilizzato per definire la lingua. Esempio:/en-US/aboutsi riferirà aen-USe/fr/aboutafr.In questa fase, incontrerai l'errore:
Error: Missing <html> and <body> tags in the root layout.. Questo è previsto perché il file/app/page.tsxnon è più in uso e può essere rimosso. Invece, il segmento di percorso[locale]attiverà la pagina/app/[locale]/page.tsx. Di conseguenza, le pagine saranno accessibili tramite percorsi come/en,/fr,/esnel tuo browser. Per impostare la lingua predefinita come pagina principale, fai riferimento alla configurazione delmiddlewarenel passo 4.Poi, implementa la funzione
generateStaticParamsnel layout della tua applicazione.src/app/[locale]/layout.tsxCopiare il codiceCopiare il codice nella clipboard
export { generateStaticParams } from "next-intlayer"; // Riga da inserire const LocaleLayout: Next14LayoutIntlayer = ({ children, params: { locale }, }) => { /*... Resto del codice*/ }; export default LocaleLayout;generateStaticParamsgarantisce che la tua applicazione pre-costruisca le pagine necessarie per tutte le lingue, riducendo il calcolo a runtime e migliorando l'esperienza utente. Per maggiori dettagli, consulta la documentazione di Next.js su generateStaticParams.Dichiara i tuoi contenuti
Crea e gestisci le dichiarazioni dei tuoi contenuti per memorizzare le traduzioni:
src/app/[locale]/page.content.tsCopiare il codiceCopiare il codice nella clipboard
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", it: "Inizia modificando", }), pageLink: "src/app/page.tsx", }, }, } satisfies Dictionary; export default pageContent;Le dichiarazioni dei tuoi contenuti possono essere definite ovunque nella tua applicazione purché siano incluse nella directory
contentDir(di default,./src). E corrispondano all'estensione del file di dichiarazione dei contenuti (di default,.content.{json,ts,tsx,js,jsx,mjs,cjs}).Per maggiori dettagli, consulta la documentazione sulla dichiarazione dei contenuti.
Utilizza i contenuti nel tuo codice
Accedi ai tuoi dizionari di contenuti in tutta la tua applicazione:
src/app/[locale]/page.tsxCopiare il codiceCopiare il codice nella clipboard
import { ClientComponentExample } from "@components/ClientComponentExample"; import { ServerComponentExample } from "@components/ServerComponentExample"; import { type Next14PageIntlayer } from "next-intlayer"; import { IntlayerServerProvider, useIntlayer } from "next-intlayer/server"; const Page: Next14PageIntlayer = ({ params: { locale } }) => { const content = useIntlayer("page", locale); return ( <> <p> {content.getStarted.main} <code>{content.getStarted.pageLink}</code> </p> <IntlayerServerProvider locale={locale}> <ServerComponentExample /> <ClientComponentExample /> </IntlayerServerProvider> </> ); }; export default Page;IntlayerClientProviderè utilizzato per fornire la lingua ai componenti lato client. Può essere posizionato in qualsiasi componente genitore, incluso il layout. Tuttavia, è consigliato posizionarlo in un layout perché Next.js condivide il codice del layout tra le pagine, rendendolo più efficiente. UtilizzandoIntlayerClientProvidernel layout, eviti di reinizializzarlo per ogni pagina, migliorando le prestazioni e mantenendo un contesto di localizzazione coerente in tutta l'applicazione.IntlayerServerProviderè utilizzato per fornire la lingua ai figli lato server. Non può essere impostato nel layout.Layout e pagina non possono condividere un contesto server comune perché il sistema di contesto server si basa su un archivio dati per richiesta (tramite il meccanismo di cache di React), causando la ricreazione di ogni "contesto" per segmenti diversi dell'applicazione. Posizionare il provider in un layout condiviso interromperebbe questo isolamento, impedendo la corretta propagazione dei valori del contesto server ai tuoi componenti server.
src/components/ClientComponentExample.tsxCopiare il codiceCopiare il codice nella clipboard
"use client"; import type { FC } from "react"; import { useIntlayer } from "next-intlayer"; const ClientComponentExample: FC = () => { const content = useIntlayer("client-component-example"); // Crea la dichiarazione dei contenuti correlata return ( <div> <h2>{content.title}</h2> <p>{content.content}</p> </div> ); };src/components/ServerComponentExample.tsxCopiare il codiceCopiare il codice nella clipboard
import type { FC } from "react"; import { useIntlayer } from "next-intlayer/server"; const ServerComponentExample: FC = () => { const content = useIntlayer("server-component-example"); // Crea la dichiarazione dei contenuti correlata return ( <div> <h2>{content.title}</h2> <p>{content.content}</p> </div> ); };Se desideri utilizzare i tuoi contenuti in un attributo
string, comealt,title,href,aria-label, ecc., devi chiamare il valore della funzione, come:htmlCopiare il codiceCopiare il codice nella clipboard
<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)}" />Per saperne di più sull'hook
useIntlayer, consulta la documentazione.Internazionalizzazione dei tuoi metadati
OpzionaleNel caso tu voglia internazionalizzare i tuoi metadati, come il titolo della tua pagina, puoi utilizzare la funzione
generateMetadatafornita da Next.js. All'interno della funzione utilizza la funzionegetTranslationper tradurre i tuoi metadati.src/app/[locale]/layout.tsx or src/app/[locale]/page.tsxCopiare il codiceCopiare il codice nella clipboard
import { type IConfigLocales, getTranslation, getMultilingualUrls,} from "intlayer";import type { Metadata } from "next";import type { LocalParams } from "next-intlayer";export const generateMetadata = ({ params: { locale },}: LocalParams): Metadata => { const t = <T>(content: IConfigLocales<T>) => getTranslation(content, locale); /** * Genera un oggetto contenente tutti gli URL per ogni lingua. * * Esempio: * ```ts * getMultilingualUrls('/about'); * * // Restituisce * // { * // en: '/about', * // fr: '/fr/about', * // es: '/es/about', * // } * ``` */ const multilingualUrls = getMultilingualUrls("/"); return { title: t<string>({ en: "My title", fr: "Mon titre", es: "Mi título", it: "Il mio titolo", }), description: t({ en: "My description", fr: "Ma description", es: "Mi descripción", it: "La mia descrizione", }), alternates: { canonical: multilingualUrls[locale as keyof typeof multilingualUrls], languages: { ...multilingualUrls, "x-default": "/" }, }, openGraph: { url: multilingualUrls[locale], }, };};// ... Resto del codiceScopri di più sull'ottimizzazione dei metadati nella documentazione ufficiale di Next.js.
Internazionalizzazione del tuo sitemap.xml e robots.txt
OpzionalePer internazionalizzare il tuo
sitemap.xmlerobots.txt, puoi utilizzare la funzionegetMultilingualUrlsfornita da Intlayer. Questa funzione ti consente di generare URL multilingue per il tuo sitemap.src/app/sitemap.tsCopiare il codiceCopiare il codice nella clipboard
import { getMultilingualUrls } from "intlayer"; import type { MetadataRoute } from "next"; const sitemap = (): MetadataRoute.Sitemap => [ { url: "https://example.com", alternates: { languages: getMultilingualUrls("https://example.com"), }, }, { url: "https://example.com/login", alternates: { languages: getMultilingualUrls("https://example.com/login"), }, }, { url: "https://example.com/register", alternates: { languages: getMultilingualUrls("https://example.com/register"), }, }, ]; export default sitemap;src/app/robots.tsCopiare il codiceCopiare il codice nella clipboard
import type { MetadataRoute } from "next"; import { getMultilingualUrls } from "intlayer"; const getAllMultilingualUrls = (urls: string[]) => urls.flatMap((url) => Object.values(getMultilingualUrls(url)) as string[]); const robots = (): MetadataRoute.Robots => ({ rules: { userAgent: "*", allow: ["/"], disallow: getAllMultilingualUrls(["/login", "/register"]), }, host: "https://example.com", sitemap: `https://example.com/sitemap.xml`, }); export default robots;Scopri di più sull'ottimizzazione del sitemap nella documentazione ufficiale di Next.js. Scopri di più sull'ottimizzazione del robots.txt nella documentazione ufficiale di Next.js.
Cambia la lingua dei tuoi contenuti
OpzionalePer cambiare la lingua dei tuoi contenuti in Next.js, il modo consigliato è utilizzare il componente
Linkper reindirizzare gli utenti alla pagina localizzata appropriata. Il componenteLinkconsente il prefetching della pagina, il che aiuta a evitare un ricaricamento completo della pagina.src/components/LocaleSwitcher.tsxCopiare il codiceCopiare il codice nella clipboard
"use client"; import { Locales, getHTMLTextDir, getLocaleName, getLocalizedUrl, } from "intlayer"; import { useLocale } from "next-intlayer"; import { type FC } from "react"; import Link from "next/link"; 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)} hrefLang={localeItem} key={localeItem} aria-current={locale === localeItem ? "page" : undefined} onClick={() => setLocale(localeItem)} > <span> {/* Lingua - es. FR */} {localeItem} </span> <span> {/* Lingua nel proprio locale - es. Français */} {getLocaleName(localeItem, locale)} </span> <span dir={getHTMLTextDir(localeItem)} lang={localeItem}> {/* Lingua nel locale corrente - es. Francés con locale corrente impostato su Locales.SPANISH */} {getLocaleName(localeItem)} </span> <span dir="ltr" lang={Locales.ENGLISH}> {/* Lingua in inglese - es. French */} {getLocaleName(localeItem, Locales.ENGLISH)} </span> </Link> ))} </div> </div> ); };Riferimenti alla documentazione:
Creazione di un componente Link localizzato
OpzionalePer garantire che la navigazione della tua applicazione rispetti la lingua corrente, puoi creare un componente
Linkpersonalizzato. Questo componente aggiunge automaticamente il prefisso agli URL interni con la lingua corrente, in modo che, ad esempio, quando un utente francofono clicca su un link alla pagina "About", venga reindirizzato a/fr/aboutinvece che a/about.Questo comportamento è utile per diversi motivi:
- SEO e User Experience: Gli URL localizzati aiutano i motori di ricerca a indicizzare correttamente le pagine specifiche per lingua e forniscono agli utenti contenuti nella loro lingua preferita.
- Coerenza: Utilizzando un link localizzato in tutta l'applicazione, garantisci che la navigazione rimanga all'interno della lingua corrente, evitando cambi di lingua inaspettati.
- Manutenibilità: Centralizzando la logica di localizzazione in un unico componente, semplifichi la gestione degli URL, rendendo il tuo codice più facile da mantenere ed estendere man mano che l'applicazione cresce.
Di seguito è riportata l'implementazione di un componente
Linklocalizzato in TypeScript:src/components/Link.tsxCopiare il codiceCopiare il codice nella clipboard
"use client"; import { getLocalizedUrl } from "intlayer"; import NextLink, { type LinkProps as NextLinkProps } from "next/link"; import { useLocale } from "next-intlayer"; import { forwardRef, PropsWithChildren, type ForwardedRef } from "react"; /** * Funzione di utilità per verificare se un URL è esterno. * Se l'URL inizia con http:// o https://, viene considerato esterno. */ export const checkIsExternalLink = (href?: string): boolean => /^https?:\/\//.test(href ?? ""); /** * Un componente Link personalizzato che adatta l'attributo href in base alla lingua corrente. * Per i link interni, utilizza `getLocalizedUrl` per aggiungere il prefisso dell'URL con la lingua (es. /fr/about). * Questo garantisce che la navigazione rimanga all'interno dello stesso contesto linguistico. */ export const Link = forwardRef< HTMLAnchorElement, PropsWithChildren<NextLinkProps> >(({ href, children, ...props }, ref: ForwardedRef<HTMLAnchorElement>) => { const { locale } = useLocale(); const isExternalLink = checkIsExternalLink(href.toString()); // Se il link è interno e viene fornito un href valido, ottieni l'URL localizzato. const hrefI18n: NextLinkProps["href"] = href && !isExternalLink ? getLocalizedUrl(href.toString(), locale) : href; return ( <NextLink href={hrefI18n} ref={ref} {...props}> {children} </NextLink> ); }); Link.displayName = "Link";Come Funziona
Rilevamento dei Link Esterni:
La funzione helpercheckIsExternalLinkdetermina se un URL è esterno. I link esterni vengono lasciati invariati perché non necessitano di localizzazione.Recupero della Lingua Corrente:
L'hookuseLocalefornisce la lingua corrente (es.frper il francese).Localizzazione dell'URL:
Per i link interni (cioè non esterni),getLocalizedUrlviene utilizzato per aggiungere automaticamente il prefisso dell'URL con la lingua corrente. Ciò significa che se il tuo utente è in francese, passando/aboutcomehrefverrà trasformato in/fr/about.Restituzione del Link:
Il componente restituisce un elemento<a>con l'URL localizzato, garantendo che la navigazione sia coerente con la lingua.
Integrando questo componente
Linkin tutta la tua applicazione, mantieni un'esperienza utente coerente e consapevole della lingua, beneficiando anche di un miglior SEO e usabilità.Ottimizza la dimensione del tuo bundle
OpzionaleQuando si utilizza
next-intlayer, i dizionari sono inclusi nel bundle per ogni pagina per impostazione predefinita. Per ottimizzare la dimensione del bundle, Intlayer fornisce un plugin SWC opzionale che sostituisce in modo intelligente le chiamate auseIntlayerutilizzando macro. Questo assicura che i dizionari siano inclusi solo nei bundle delle pagine che li utilizzano effettivamente.Per abilitare questa ottimizzazione, installa il pacchetto
@intlayer/swc. Una volta installato,next-intlayerrileverà e utilizzerà automaticamente il plugin:bashCopiare il codiceCopiare il codice nella clipboard
npm install @intlayer/swc --save-devNota: Questa ottimizzazione è disponibile solo per Next.js 13 e versioni successive.
Nota: Questo pacchetto non è installato di default perché i plugin SWC sono ancora sperimentali su Next.js. Potrebbe cambiare in futuro.
Configura TypeScript
Intlayer utilizza l'augmentazione dei moduli per ottenere i vantaggi di TypeScript e rendere il tuo codice più robusto.


Assicurati che la configurazione di TypeScript includa i tipi autogenerati.
Copiare il codice nella clipboard
{ // ... Le tue configurazioni TypeScript esistenti "include": [ // ... Le tue configurazioni TypeScript esistenti ".intlayer/**/*.ts", // Includi i tipi autogenerati ],}Configurazione Git
Si consiglia di ignorare i file generati da Intlayer. Questo ti consente di evitare di commetterli nel tuo repository Git.
Per fare ciò, puoi aggiungere le seguenti istruzioni al tuo file .gitignore:
Copiare il codice nella clipboard
# Ignora i file generati da Intlayer.intlayerApprofondisci
Per approfondire, puoi implementare l'editor visivo o esternalizzare i tuoi contenuti utilizzando il CMS.