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
- "Aggiungi comando init"v7.5.930/12/2025
- "Inizializzazione della cronologia"v7.1.1020/11/2025
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 il tuo sito SvelteKit usando Intlayer | Internazionalizzazione (i18n)
Indice
Perché Intlayer rispetto alle alternative?
Rispetto alle soluzioni principali come svelte-i18n o i18next, Intlayer è una soluzione dotata di ottimizzazioni integrate come:
Intlayer è ottimizzato per funzionare perfettamente con SvelteKit offrendo routing multilingue, supporto SSR e tutte le funzionalità necessarie per scalare l'internazionalizzazione (i18n).
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 SvelteKit
Per iniziare, crea un nuovo progetto SvelteKit. Ecco la struttura finale che realizzeremo:
Copiare il codice nella clipboard
.├── intlayer.config.ts├── package.json├── src│ ├── app.d.ts│ ├── app.html│ ├── hooks.server.ts│ ├── lib│ │ ├── getLocale.ts│ │ ├── LocaleSwitcher.svelte│ │ └── LocalizedLink.svelte│ ├── params│ │ └── locale.ts│ └── routes│ ├── [[locale=locale]]│ │ ├── +layout.svelte│ │ ├── +layout.ts│ │ ├── +page.svelte│ │ ├── +page.ts│ │ ├── about│ │ │ ├── +page.svelte│ │ │ ├── +page.ts│ │ │ └── page.content.ts│ │ ├── Counter.content.ts│ │ ├── Counter.svelte│ │ ├── Header.content.ts│ │ ├── Header.svelte│ │ ├── home.content.ts│ │ └── layout.content.ts│ ├── +layout.svelte│ └── layout.css├── static│ ├── favicon.svg│ └── robots.txt├── svelte.config.js├── tsconfig.json└── vite.config.tsInstallare le Dipendenze
Installa i pacchetti necessari usando npm:
bashCopiare il codiceCopiare il codice nella clipboard
npm install intlayer svelte-intlayernpm install vite-intlayer --save-devnpx intlayer init- intlayer: Il pacchetto core per l'internazionalizzazione (i18n).
- svelte-intlayer: Fornisce context provider e store per Svelte/SvelteKit.
- vite-intlayer: Il plugin Vite per integrare le dichiarazioni di contenuto nel processo di build.
Configurazione del tuo progetto
Crea un file di configurazione nella root del tuo progetto:
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], defaultLocale: Locales.ENGLISH, },};export default config;Integrare Intlayer nella Configurazione di Vite
Aggiorna il tuo
vite.config.tsper includere il plugin Intlayer. Questo plugin gestisce la transpilation dei tuoi file di contenuto.vite.config.tsCopiare il codiceCopiare il codice nella clipboard
import { sveltekit } from "@sveltejs/kit/vite";import { defineConfig } from "vite";import { intlayer } from "vite-intlayer";export default defineConfig({ plugins: [intlayer(), sveltekit()], // l'ordine è importante, Intlayer deve essere posizionato prima di SvelteKit});Dichiarare il Tuo Contenuto
Crea i tuoi file di dichiarazione del contenuto in qualsiasi punto della cartella
src(ad esempio,src/lib/contento accanto ai tuoi componenti). Questi file definiscono il contenuto traducibile per la tua applicazione utilizzando la funzionet()per ogni locale.Utilizzare Intlayer nei Tuoi Componenti
Ora puoi usare la funzione
useIntlayerin qualsiasi componente Svelte. Essa restituisce uno store reattivo che si aggiorna automaticamente quando cambia la locale. La funzione rispetterà automaticamente la locale corrente (sia durante SSR che nella navigazione lato client).Nota:
useIntlayerrestituisce uno store Svelte, quindi devi usare il prefisso `--- createdAt: 2025-11-20 updatedAt: 2026-05-31 title: Come tradurre la tua app SvelteKit – guida i18n 2026 description: Scopri come rendere il tuo sito SvelteKit multilingue. Segui la documentazione per internazionalizzare (i18n) e tradurlo utilizzando il Server-Side Rendering (SSR). keywords:- Internazionalizzazione
- Documentazione
- Intlayer
- SvelteKit
- JavaScript
- SSR slugs:
- doc
- environment
- sveltekit applicationTemplate: https://github.com/aymericzip/intlayer-sveltekit-template history:
- version: 7.1.10 date: 2025-11-20 changes: Inizializzazione della cronologia
Traduci il tuo sito SvelteKit usando Intlayer | Internazionalizzazione (i18n)
Indice
Cos'è Intlayer?
Intlayer è una libreria innovativa e open-source per l'internazionalizzazione (i18n) progettata per semplificare il supporto multilingue nelle moderne applicazioni web. Funziona perfettamente con le capacità di Server-Side Rendering (SSR) di SvelteKit.
Con Intlayer, puoi:
- Gestire facilmente le traduzioni utilizzando dizionari dichiarativi a livello di componente.
- Localizzare dinamicamente i metadata, le rotte e i contenuti.
- Garantire il supporto TypeScript con tipi autogenerati.
- Sfruttare l'SSR di SvelteKit per un'internazionalizzazione SEO-friendly.
Guida passo-passo per configurare Intlayer in un'applicazione SvelteKit
Per iniziare, crea un nuovo progetto SvelteKit. Ecco la struttura finale che realizzeremo:
Copiare il codice nella clipboard
.├── intlayer.config.ts├── package.json├── src│ ├── app.d.ts│ ├── app.html│ ├── hooks.server.ts│ ├── lib│ │ ├── getLocale.ts│ │ ├── LocaleSwitcher.svelte│ │ └── LocalizedLink.svelte│ ├── params│ │ └── locale.ts│ └── routes│ ├── [[locale=locale]]│ │ ├── +layout.svelte│ │ ├── +layout.ts│ │ ├── +page.svelte│ │ ├── +page.ts│ │ ├── about│ │ │ ├── +page.svelte│ │ │ ├── +page.ts│ │ │ └── page.content.ts│ │ ├── Counter.content.ts│ │ ├── Counter.svelte│ │ ├── Header.content.ts│ │ ├── Header.svelte│ │ ├── home.content.ts│ │ └── layout.content.ts│ ├── +layout.svelte│ └── layout.css├── static│ ├── favicon.svg│ └── robots.txt├── svelte.config.js├── tsconfig.json└── vite.config.tsInstallare le Dipendenze
Installa i pacchetti necessari usando npm:
bashCopiare il codiceCopiare il codice nella clipboard
npm install intlayer svelte-intlayernpm install vite-intlayer --save-devnpx intlayer init- intlayer: Il pacchetto core per l'internazionalizzazione (i18n).
- svelte-intlayer: Fornisce context provider e store per Svelte/SvelteKit.
- vite-intlayer: Il plugin Vite per integrare le dichiarazioni di contenuto nel processo di build.
Configurazione del tuo progetto
Crea un file di configurazione nella root del tuo progetto:
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], defaultLocale: Locales.ENGLISH, },};export default config;Integrare Intlayer nella Configurazione di Vite
Aggiorna il tuo
vite.config.tsper includere il plugin Intlayer. Questo plugin gestisce la transpilation dei tuoi file di contenuto.vite.config.tsCopiare il codiceCopiare il codice nella clipboard
import { sveltekit } from "@sveltejs/kit/vite";import { defineConfig } from "vite";import { intlayer } from "vite-intlayer";export default defineConfig({ plugins: [intlayer(), sveltekit()], // l'ordine è importante, Intlayer deve essere posizionato prima di SvelteKit});Dichiarare il Tuo Contenuto
Crea i tuoi file di dichiarazione del contenuto in qualsiasi punto della cartella
src(ad esempio,src/lib/contento accanto ai tuoi componenti). Questi file definiscono il contenuto traducibile per la tua applicazione utilizzando la funzionet()per ogni locale.Utilizzare Intlayer nei Tuoi Componenti
per accedere al suo valore reattivo (ad esempio,
$content.title).src/lib/components/Component.svelteCopiare il codiceCopiare il codice nella clipboard
<script lang="ts"> import { useIntlayer } from "svelte-intlayer"; // "hero-section" corrisponde alla chiave definita nel Passo 4 const content = useIntlayer("hero-section");</script><!-- Renderizza il contenuto come contenuto semplice --><h1>{$content.title}</h1><!-- Per rendere il contenuto modificabile usando l'editor --><h1>{@const Title = $content.title}<Title /></h1><!-- Per rendere il contenuto come stringa --><div aria-label={$content.title.value}></div><div aria-label={$content.title.toString()}></div><div aria-label={String($content.title)}></div>Configurare il routing
OpzionaleI passaggi seguenti mostrano come configurare il routing basato sulla locale in SvelteKit. Questo permette agli URL di includere il prefisso della locale (es.
/en/about,/fr/about) per migliorare la SEO e l'esperienza utente.bashCopiare il codiceCopiare il codice nella clipboard
.└─── src ├── app.d.ts # Definisce il tipo di locale ├── hooks.server.ts # Gestisce il routing della locale ├── lib │ └── getLocale.ts # Controlla la locale dall'header, cookie ├── params │ └── locale.ts # Definisce il parametro locale └── routes ├── [[locale=locale]] # Raggruppa in un gruppo di route per impostare la locale │ ├── +layout.svelte # Layout locale per la route │ ├── +layout.ts │ ├── +page.svelte │ ├── +page.ts │ └── about │ ├── +page.svelte │ └── +page.ts └── +layout.svelte # Layout radice per i font e gli stili globaliGestire il Rilevamento della Locale lato Server
In SvelteKit, il server deve conoscere la locale dell'utente per renderizzare il contenuto corretto durante il SSR. Usiamo
hooks.server.tsper rilevare la locale dall'URL o dai cookie.Crea o modifica
src/hooks.server.ts:src/hooks.server.tsCopiare il codiceCopiare il codice nella clipboard
import type { Handle } from "@sveltejs/kit";import { getLocalizedUrl } from "intlayer";import { getLocale } from "$lib/getLocale";export const handle: Handle = async ({ event, resolve }) => { const detectedLocale = getLocale(event); // Controlla se il percorso corrente inizia già con una locale (es. /fr, /en) const pathname = event.url.pathname; const targetPathname = getLocalizedUrl(pathname, detectedLocale); // Se NON è presente una locale nell'URL (es. l'utente visita "/"), reindirizzalo if (targetPathname !== pathname) { return new Response(undefined, { headers: { Location: targetPathname }, status: 307, // Reindirizzamento temporaneo }); } return resolve(event, { transformPageChunk: ({ html }) => html.replace("%lang%", detectedLocale), });};Quindi, crea un helper per ottenere la locale dell'utente dall'evento della richiesta:
src/lib/getLocale.tsCopiare il codiceCopiare il codice nella clipboard
import { configuration, getLocaleFromStorage, localeDetector, type Locale,} from "intlayer";import type { RequestEvent } from "@sveltejs/kit";/** * Ottieni la locale dell'utente dall'evento di richiesta. * Questa funzione è utilizzata nel hook `handle` in `src/hooks.server.ts`. * * Prima tenta di ottenere la locale dallo storage di Intlayer (cookie o header personalizzati). * Se la locale non viene trovata, ricorre alla negoziazione "Accept-Language" del browser. * * @param event - L'evento di richiesta da SvelteKit * @returns La locale dell'utente */export const getLocale = (event: RequestEvent): Locale => { const defaultLocale = configuration?.internationalization?.defaultLocale; // Prova a ottenere la locale dallo storage di Intlayer (cookie o header) const storedLocale = getLocaleFromStorage({ // Accesso ai cookie di SvelteKit getCookie: (name: string) => event.cookies.get(name) ?? null, // Accesso alle intestazioni di SvelteKit getHeader: (name: string) => event.request.headers.get(name) ?? null, }); if (storedLocale) { return storedLocale; } // Ripiego sulla negoziazione "Accept-Language" del browser const negotiatorHeaders: Record<string, string> = {}; // Conversione dell'oggetto Headers di SvelteKit in un semplice Record<string, string> event.request.headers.forEach((value, key) => { negotiatorHeaders[key] = value; }); // Controlla la locale dall'intestazione `Accept-Language` const userFallbackLocale = localeDetector(negotiatorHeaders); if (userFallbackLocale) { return userFallbackLocale; } // Restituisce la locale di default se non viene trovata una corrispondenza return defaultLocale;};getLocaleFromStoragecontrollerà la locale dall'header o dal cookie a seconda della tua configurazione. Vedi Configurazione per maggiori dettagli.La funzione
localeDetectorgestirà l'headerAccept-Languagee restituirà la corrispondenza migliore.Se la locale non è configurata, vogliamo restituire un errore 404. Per semplificare, possiamo creare una funzione
matchper verificare se la locale è valida:/src/params/locale.tsCopiare il codiceCopiare il codice nella clipboard
export const match = (param: Locale = defaultLocale): boolean => locales.includes(param);Nota: Assicurati che il tuo file
src/app.d.tsincluda la definizione della locale:typescriptCopiare il codiceCopiare il codice nella clipboard
declare global { namespace App { interface Locals { locale: import("intlayer").Locale; } }}Per il file
+layout.svelte, possiamo rimuovere tutto, mantenendo solo contenuti statici, non correlati a i18n:src/+layout.svelteCopiare il codiceCopiare il codice nella clipboard
<script lang="ts"> import './layout.css'; let { children } = $props();</script><div class="app"> {@render children()}</div><style> .app { /* */ }</style>Successivamente, crea una nuova pagina e layout sotto il gruppo
[[locale=locale]]:src/routes/[[locale=locale]]/+layout.tsCopiare il codiceCopiare il codice nella clipboard
import type { Load } from "@sveltejs/kit";import { defaultLocale, type Locale } from "intlayer";export const prerender = true;// Usa il tipo generico Loadexport const load: Load = ({ params }) => { const locale: Locale = (params.locale as Locale) ?? defaultLocale; return { locale, };};src/routes/[[locale=locale]]/+layout.svelteCopiare il codiceCopiare il codice nella clipboard
<script lang="ts"> import type { Snippet } from 'svelte'; import { useIntlayer, setupIntlayer } from "svelte-intlayer"; import Header from './Header.svelte'; import type { LayoutData } from './$types'; let { children, data }: { children: Snippet, data: LayoutData } = $props(); // Inizializza Intlayer con la locale dalla route $effect(() => { setupIntlayer(data.locale); }); // Usa il dizionario dei contenuti del layout const layoutContent = useIntlayer('layout');</script><Header /><main> {@render children()}</main><footer> <p> {$layoutContent.footer.prefix.value}{' '} <a href="https://svelte.dev/docs/kit">{$layoutContent.footer.linkLabel.value}</a>{' '} {$layoutContent.footer.suffix.value} </p></footer><style> /* */</style>src/routes/[[locale=locale]]/+page.tsCopiare il codiceCopiare il codice nella clipboard
export const prerender = true;src/routes/[[locale=locale]]/+page.svelteCopiare il codiceCopiare il codice nella clipboard
<script lang="ts"> import { useIntlayer } from "svelte-intlayer"; // Usa il dizionario dei contenuti della home const homeContent = useIntlayer('home');</script><svelte:head> <title>{$homeContent.title.value}</title></svelte:head><section> <h1> {$homeContent.title} </h1></section><style> /* */</style>Link Internazionalizzati
OpzionalePer la SEO, si consiglia di anteporre alle tue rotte la locale (ad esempio,
/en/about,/fr/about). Questo componente antepone automaticamente qualsiasi link con la locale corrente.src/lib/components/LocalizedLink.svelteCopiare il codiceCopiare il codice nella clipboard
<script lang="ts"> import { getLocalizedUrl } from "intlayer"; import { useLocale } from "svelte-intlayer"; let { href = "" } = $props(); const { locale } = useLocale(); // Helper per anteporre l'URL con la locale corrente $: localizedHref = getLocalizedUrl(href, $locale);</script><a href={localizedHref}> <slot /></a>Se usi
gotodi SvelteKit, puoi usare la stessa logica congetLocalizedUrlper navigare all'URL localizzato:typescriptCopiare il codiceCopiare il codice nella clipboard
import { goto } from "$app/navigation";import { getLocalizedUrl } from "intlayer";import { useLocale } from "svelte-intlayer";const { locale } = useLocale();const localizedPath = getLocalizedUrl("/about", $locale);goto(localizedPath); // Naviga verso /en/about o /fr/about a seconda della localeSelettore di Lingua
OpzionalePer permettere agli utenti di cambiare lingua, aggiorna l'URL.
src/lib/components/LanguageSwitcher.svelteCopiare il codiceCopiare il codice nella clipboard
<script lang="ts"> import { getLocalizedUrl, getLocaleName } from 'intlayer'; import { useLocale } from "svelte-intlayer"; import { page } from '$app/stores'; import { goto } from '$app/navigation'; const { locale, setLocale, availableLocales } = useLocale({ onLocaleChange: (newLocale) => { const localizedPath = getLocalizedUrl($page.url.pathname, newLocale); goto(localizedPath); }, });</script><ul class="locale-list"> {#each availableLocales as localeEl} <li> <a href={getLocalizedUrl($page.url.pathname, localeEl)} onclick={(e) => { e.preventDefault(); setLocale(localeEl); // Imposterà la locale nello store e attiverà onLocaleChange }} class:active={$locale === localeEl} > {getLocaleName(localeEl)} </a> </li> {/each}</ul><style> /* */</style>Aggiungere un proxy backend
OpzionalePer aggiungere un proxy backend alla tua applicazione SvelteKit, puoi usare la funzione
intlayerProxyfornita dal pluginvite-intlayer. Questo plugin rileverà automaticamente la migliore locale per l'utente basandosi sull'URL, i cookie e le preferenze della lingua del browser.vite.config.tsCopiare il codiceCopiare il codice nella clipboard
import { defineConfig } from "vite";import { intlayer, intlayerProxy } from "vite-intlayer";import { sveltekit } from "@sveltejs/kit/vite";// https://vitejs.dev/config/export default defineConfig({ plugins: [ intlayerProxy(), // should be placed first intlayer(), sveltekit(), ],],});Configurare l'editor / CMS di intlayer
OpzionalePer configurare l'editor di intlayer, devi seguire la documentazione dell'editor di intlayer.
Per configurare il CMS di intlayer, devi seguire la documentazione del CMS di intlayer.
Per poter visualizzare il selettore dell'editor intlayer, dovrai utilizzare la sintassi del componente nel tuo contenuto intlayer.
Component.svelteCopiare il codiceCopiare il codice nella clipboard
<script lang="ts"> import { useIntlayer } from "svelte-intlayer"; const content = useIntlayer("component");</script><div> <!-- Renderizza il contenuto come contenuto semplice --> <h1>{$content.title}</h1> <!-- Renderizza il contenuto come componente (richiesto dall'editor) --> {@const Component = $content.component}<Component /></div>Estrarre il contenuto dei tuoi componenti
OpzionaleSe hai una base di codice esistente, trasformare migliaia di file può richiedere molto tempo.
Per facilitare questo processo, Intlayer propone un compilatore / estrattore per trasformare i tuoi componenti ed estrarre il contenuto.
Per configurarlo, puoi aggiungere una sezione
compilernel tuo fileintlayer.config.ts:intlayer.config.tsCopiare il codiceCopiare il codice nella clipboard
import { type IntlayerConfig } from "intlayer"; const config: IntlayerConfig = { // ... Resto della tua configurazione compiler: { /** * Indica se il compilatore deve essere abilitato. */ enabled: true, /** * Definisce il percorso dei file di output */ output: ({ fileName, extension }) => `./${fileName}${extension}`, /** * Indica se i componenti devono essere salvati dopo essere stati trasformati. In questo modo, il compilatore può essere eseguito solo una volta per trasformare l'app e poi rimosso. */ saveComponents: false, /** * Prefisso chiave dizionario */ dictionaryKeyPrefix: "", }, }; export default config;Esegui l'estrattore per trasformare i tuoi componenti ed estrarre il contenuto
bashCopiare il codiceCopiare il codice nella clipboard
npx intlayer extract
Configurazione Git
Si consiglia di ignorare i file generati da Intlayer.
Copiare il codice nella clipboard
# Ignora i file generati da Intlayer.intlayerApprofondimenti
Per poter visualizzare il selettore dell'editor intlayer, dovrai utilizzare la sintassi del componente nel tuo contenuto intlayer.
Copiare il codice nella clipboard
<script lang="ts"> import { useIntlayer } from "svelte-intlayer"; const content = useIntlayer("component");</script><div> <!-- Renderizza il contenuto come contenuto semplice --> <h1>{$content.title}</h1> <!-- Renderizza il contenuto come componente (richiesto dall'editor) --> {@const Component = $content.component}<Component /></div>Configurazione Git
Si consiglia di ignorare i file generati da Intlayer.
Copiare il codice nella clipboard
# Ignora i file generati da Intlayer.intlayerVai oltre
- Visual Editor: integra il Visual Editor di Intlayer per modificare le traduzioni direttamente dall'interfaccia utente.
- CMS: esternalizza la gestione dei tuoi contenuti utilizzando il CMS di Intlayer.