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
- "Inizio cronologia"v5.5.1029/06/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 la tua Vite and Preact con Intlayer | Internazionalizzazione (i18n)
Questo pacchetto è in fase di sviluppo. Consulta la issue per maggiori informazioni. Mostra il tuo interesse per Intlayer per Preact mettendo un like alla issue
Consulta il Template dell'Applicazione su GitHub.
Perché Intlayer rispetto alle alternative?
Rispetto alle soluzioni principali come preact-i18n o i18next, Intlayer è una soluzione dotata di ottimizzazioni integrate come:
Intlayer è ottimizzato per funzionare perfettamente con Preact offrendo ambito del contenuto a livello di componente, traduzioni caricate lazy 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 Vite e Preact
Installa le Dipendenze
Installa i pacchetti necessari usando npm:
bashCopiare il codiceCopiare il codice nella clipboard
npm install intlayer preact-intlayernpm install vite-intlayer --save-devnpx intlayer initintlayer
Il pacchetto principale che fornisce strumenti di internazionalizzazione per la gestione della configurazione, la traduzione, la dichiarazione dei contenuti, la traspilazione e i comandi CLI.
preact-intlayer Il pacchetto che integra Intlayer con l'applicazione Preact. Fornisce provider di contesto e hook per l'internazionalizzazione in Preact.
vite-intlayer Include il plugin Vite per integrare Intlayer con il bundler Vite, oltre a middleware per rilevare la lingua preferita dall'utente, gestire i cookie e gestire il reindirizzamento degli URL.
Configurazione del tuo progetto
Crea un file di configurazione per impostare 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, }, routing: { mode: "prefix-no-default", // Default: prefisso per tutte le lingue tranne quella predefinita storage: ["cookie", "header"], // Default: memorizza la lingua nei cookie e rileva dall'header }, }; export default config;Attraverso questo file di configurazione, puoi impostare URL localizzati, modalità di routing, opzioni di memorizzazione, nomi dei cookie, la posizione e l'estensione delle tue dichiarazioni di contenuto, 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 tua configurazione Vite
Aggiungi il plugin intlayer nella tua configurazione.
vite.config.tsCopiare il codiceCopiare il codice nella clipboard
import { defineConfig } from "vite"; import preact from "@preact/preset-vite"; import { intlayer } from "vite-intlayer"; // https://vitejs.dev/config/ export default defineConfig({ plugins: [preact(), intlayer()], });Il plugin Vite
intlayer()viene utilizzato per integrare Intlayer con Vite. Garantisce la costruzione dei file di dichiarazione dei contenuti e li monitora in modalità sviluppo. Definisce le variabili d'ambiente di Intlayer all'interno dell'applicazione Vite. Inoltre, fornisce alias per ottimizzare le prestazioni.Dichiara i Tuoi Contenuti
Crea e gestisci le tue dichiarazioni di contenuto per memorizzare le traduzioni:
src/app.content.tsxCopiare il codiceCopiare il codice nella clipboard
import { t, type Dictionary } from "intlayer"; import type { ComponentChildren } from "preact"; const appContent = { key: "app", content: { viteLogo: t({ en: "Vite logo", fr: "Logo Vite", es: "Logo Vite", }), preactLogo: t({ en: "Preact logo", fr: "Logo Preact", es: "Logo Preact", }), title: "Vite + Preact", count: t({ en: "count is ", fr: "le compte est ", es: "el recuento es ", }), edit: t<ComponentChildren>({ en: ( <> Edit <code>src/app.tsx</code> and save to test HMR </> ), fr: ( <> Éditez <code>src/app.tsx</code> et enregistrez pour tester HMR </> ), es: ( <> Edita <code>src/app.tsx</code> y guarda para probar HMR </> ), }), readTheDocs: t({ en: "Click on the Vite and Preact logos to learn more", fr: "Cliquez sur les logos Vite et Preact pour en savoir plus", es: "Haga clic en los logotipos de Vite y Preact para obtener más información", }), }, } satisfies Dictionary; export default appContent;Le tue dichiarazioni di contenuto possono essere definite ovunque nella tua applicazione non appena sono incluse nella directory
contentDir(per impostazione predefinita,./src). E devono corrispondere all'estensione del file di dichiarazione del contenuto (per impostazione predefinita,.content.{json,ts,tsx,js,jsx,mjs,cjs}).Per maggiori dettagli, consulta la documentazione sulla dichiarazione del contenuto.
Se il tuo file di contenuto include codice TSX, potresti dover importare
import { h } from "preact";o assicurarti che il pragma JSX sia correttamente impostato per Preact.Utilizza Intlayer nel tuo codice
Accedi ai tuoi dizionari di contenuto in tutta l'applicazione:
src/app.tsxCopiare il codiceCopiare il codice nella clipboard
import { useState } from "preact/hooks"; import type { FunctionalComponent } from "preact"; import preactLogo from "./assets/preact.svg"; // Si presume che tu abbia un preact.svg import viteLogo from "/vite.svg"; import "./app.css"; // Si presume che il tuo file CSS si chiami app.css import { IntlayerProvider, useIntlayer } from "preact-intlayer"; const AppContent: FunctionalComponent = () => { const [count, setCount] = useState(0); const content = useIntlayer("app"); return ( <> <div> <a href="https://vitejs.dev" target="_blank"> <img src={viteLogo} class="logo" alt={content.viteLogo.value} /> </a> <a href="https://preactjs.com" target="_blank"> <img src={preactLogo} class="logo preact" alt={content.preactLogo.value} /> </a> </div> <h1>{content.title}</h1> <div class="card"> <button onClick={() => setCount((count) => count + 1)}> {content.count} {count} </button> <p>{content.edit}</p> </div> {/* Contenuto Markdown */} <div>{content.myMarkdownContent}</div> {/* Contenuto HTML */} <div>{content.myHtmlContent}</div> <p class="read-the-docs">{content.readTheDocs}</p> </> ); }; const App: FunctionalComponent = () => ( <IntlayerProvider> <AppContent /> </IntlayerProvider> ); export default App;Se vuoi usare il tuo contenuto in un attributo di tipo
string, comealt,title,href,aria-label, ecc., devi chiamare il valore della funzione, ad esempio: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)}" />Nota: In Preact,
classNameè solitamente scritto comeclass.Per saperne di più sull'hook
useIntlayer, consulta la documentazione (L'API è simile perpreact-intlayer).Se la tua app esiste già, puoi utilizzare l' Intlayer Compiler in combinazione con il comando extract per convertire migliaia di componenti in un secondo.
Cambiare la lingua del tuo contenuto
OpzionalePer cambiare la lingua del tuo contenuto, puoi usare la funzione
setLocalefornita dall'hookuseLocale. Questa funzione ti permette di impostare la localizzazione dell'applicazione e aggiornare di conseguenza il contenuto.src/components/LocaleSwitcher.tsxCopiare il codiceCopiare il codice nella clipboard
import type { FunctionalComponent } from "preact"; import { Locales } from "intlayer"; import { useLocale } from "preact-intlayer"; const LocaleSwitcher: FunctionalComponent = () => { const { setLocale } = useLocale(); return ( <button onClick={() => setLocale(Locales.ENGLISH)}> Cambia lingua in Inglese </button> ); }; export default LocaleSwitcher;Per saperne di più sull'hook
useLocale, consulta la documentazione (L'API è simile perpreact-intlayer).Aggiungi il routing localizzato alla tua applicazione
OpzionaleLo scopo di questo passaggio è creare percorsi unici per ogni lingua. Questo è utile per la SEO e per URL amichevoli per la SEO. Esempio:
plaintextCopiare il codiceCopiare il codice nella clipboard
- https://example.com/about- https://example.com/es/about- https://example.com/fr/aboutPer impostazione predefinita, le rotte non sono prefissate per la lingua predefinita. Se desideri aggiungere un prefisso anche per la lingua predefinita, puoi impostare l'opzione
routing.modesu"prefix-all"nella tua configurazione. Consulta la documentazione sulla configurazione per maggiori informazioni.Per aggiungere il routing localizzato alla tua applicazione, puoi creare un componente
LocaleRouterche avvolge le rotte della tua applicazione e gestisce il routing basato sulla lingua. Ecco un esempio che utilizza preact-iso:src/components/LocaleRouter.tsxCopiare il codiceCopiare il codice nella clipboard
import { localeMap } from "intlayer"; import { IntlayerProvider } from "preact-intlayer"; import { LocationProvider, Router, Route } from "preact-iso"; import type { ComponentChildren, FunctionalComponent } from "preact"; /** * Un componente router che configura rotte specifiche per la lingua. * Usa preact-iso per gestire la navigazione e il rendering di componenti localizzati. */ export const LocaleRouter: FunctionalComponent<{ children: ComponentChildren; }> = ({ children }) => ( <LocationProvider> <Router> {localeMap(({ locale, urlPrefix }) => ({ locale, urlPrefix })) .sort((a, b) => b.urlPrefix.length - a.urlPrefix.length) .map(({ locale, urlPrefix }) => ( <Route key={locale} path={`${urlPrefix}/:rest*`} component={() => ( <IntlayerProvider locale={locale}>{children}</IntlayerProvider> )} /> ))} </Router> </LocationProvider> );Poi, puoi usare il componente
LocaleRouternella tua applicazione:src/app.tsxCopiare il codiceCopiare il codice nella clipboard
import { LocaleRouter } from "./components/LocaleRouter"; import type { FunctionalComponent } from "preact"; // ... Il tuo componente AppContent const App: FunctionalComponent = () => ( <LocaleRouter> <AppContent /> </LocaleRouter> ); export default App;Cambia l'URL quando cambia la lingua
OpzionalePer cambiare l'URL quando la lingua cambia, puoi utilizzare la proprietà
onLocaleChangefornita dall'hookuseLocale. In parallelo, puoi usare il metodoroutediuseLocationdipreact-isoper aggiornare il percorso dell'URL.src/components/LocaleSwitcher.tsxCopiare il codiceCopiare il codice nella clipboard
import { useLocation } from "preact-iso"; import { Locales, getHTMLTextDir, getLocaleName, getLocalizedUrl, } from "intlayer"; import { useLocale } from "preact-intlayer"; import type { FunctionalComponent } from "preact"; const LocaleSwitcher: FunctionalComponent = () => { const { url, route } = useLocation(); const { locale, availableLocales, setLocale } = useLocale({ onLocaleChange: (newLocale) => { // Costruisci l'URL con la lingua aggiornata // Esempio: /es/about?foo=bar const pathWithLocale = getLocalizedUrl(url, newLocale); // Aggiorna il percorso dell'URL route(pathWithLocale, true); // true per sostituire }, }); return ( <div> <button popovertarget="localePopover">{getLocaleName(locale)}</button> <div id="localePopover" popover="auto"> {availableLocales.map((localeItem) => ( <a href={getLocalizedUrl(url, localeItem)} hreflang={localeItem} aria-current={locale === localeItem ? "page" : undefined} onClick={(e) => { e.preventDefault(); setLocale(localeItem); // La navigazione programmatica dopo il cambio di lingua sarà gestita da onLocaleChange }} key={localeItem} > <span> {/* Locale - es. FR */} {localeItem} </span> <span> {/* Lingua nella propria lingua - es. Français */} {getLocaleName(localeItem, localeItem)} </span> <span dir={getHTMLTextDir(localeItem)} lang={localeItem}> {/* Lingua nella lingua corrente - es. Francés con la lingua corrente impostata su Locales.SPANISH */} {getLocaleName(localeItem, locale)} </span> <span dir="ltr" lang={Locales.ENGLISH}> {/* Lingua in inglese - es. French */} {getLocaleName(localeItem, Locales.ENGLISH)} </span> </a> ))} </div> </div> ); }; export default LocaleSwitcher;Riferimenti alla documentazione:
- Hook
useLocale(l'API è simile perpreact-intlayer)> - HookgetLocaleName> - HookgetLocalizedUrl> - HookgetHTMLTextDir> - Attributohreflang> - Attributolang> - Attributodir> - Attributoaria-current> - API PopoverCambia gli attributi HTML di lingua e direzione
OpzionaleQuando la tua applicazione supporta più lingue, è fondamentale aggiornare gli attributi
langedirdel tag<html>per farli corrispondere alla lingua corrente. Questo garantisce:- Accessibilità: I lettori di schermo e le tecnologie assistive si basano sull'attributo
langcorretto per pronunciare e interpretare accuratamente i contenuti. - Rendering del testo: L'attributo
dir(direzione) assicura che il testo venga visualizzato nell'ordine corretto (ad esempio, da sinistra a destra per l'inglese, da destra a sinistra per l'arabo o l'ebraico), essenziale per la leggibilità. - SEO: I motori di ricerca utilizzano l'attributo
langper determinare la lingua della tua pagina, aiutando a fornire il contenuto localizzato appropriato nei risultati di ricerca.
Aggiornando dinamicamente questi attributi quando la lingua cambia, garantisci un'esperienza coerente e accessibile per gli utenti in tutte le lingue supportate.
Implementazione del Hook
Crea un hook personalizzato per gestire gli attributi HTML. L'hook ascolta i cambiamenti della lingua e aggiorna gli attributi di conseguenza:
src/hooks/useI18nHTMLAttributes.tsxCopiare il codiceCopiare il codice nella clipboard
import { useEffect } from "preact/hooks"; import { useLocale } from "preact-intlayer"; import { getHTMLTextDir } from "intlayer"; /** * Aggiorna gli attributi `lang` e `dir` dell'elemento HTML <html> in base alla lingua corrente. * - `lang`: Informa i browser e i motori di ricerca sulla lingua della pagina. * - `dir`: Garantisce l'ordine di lettura corretto (ad esempio, 'ltr' per l'inglese, 'rtl' per l'arabo). * * Questo aggiornamento dinamico è essenziale per una corretta resa del testo, accessibilità e SEO. */ export const useI18nHTMLAttributes = () => { const { locale } = useLocale(); useEffect(() => { // Aggiorna l'attributo della lingua alla lingua corrente. document.documentElement.lang = locale; // Imposta la direzione del testo in base alla lingua corrente. document.documentElement.dir = getHTMLTextDir(locale); }, [locale]); };Utilizzo del Hook nella tua Applicazione
Integra l'hook nel tuo componente principale in modo che gli attributi HTML vengano aggiornati ogni volta che la lingua cambia:
src/app.tsxCopiare il codiceCopiare il codice nella clipboard
import type { FunctionalComponent } from "preact"; import { IntlayerProvider } from "preact-intlayer"; // useIntlayer già importato se AppContent ne ha bisogno import { useI18nHTMLAttributes } from "./hooks/useI18nHTMLAttributes"; import "./app.css"; // Definizione di AppContent dal Passaggio 5 const AppWithHooks: FunctionalComponent = () => { // Applica l'hook per aggiornare gli attributi lang e dir del tag <html> in base alla lingua corrente. useI18nHTMLAttributes(); // Supponendo che AppContent sia il componente principale per la visualizzazione dei contenuti dal Passaggio 5 return <AppContent />; }; const App: FunctionalComponent = () => ( <IntlayerProvider> <AppWithHooks /> </IntlayerProvider> ); export default App;- Accessibilità: I lettori di schermo e le tecnologie assistive si basano sull'attributo
Creazione di un componente di collegamento localizzato
OpzionalePer garantire che la navigazione della tua applicazione rispetti la lingua corrente, puoi creare un componente
Linkpersonalizzato. Questo componente aggiunge automaticamente il prefisso della lingua corrente agli URL interni.Questo comportamento è utile per diversi motivi:
- SEO ed esperienza utente: 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 collegamento localizzato in tutta l'applicazione, garantisci che la navigazione rimanga all'interno della lingua corrente, evitando cambiamenti di lingua imprevisti.
- Manutenibilità: Centralizzare la logica di localizzazione in un unico componente semplifica la gestione degli URL.
Di seguito è riportata l'implementazione di un componente
Linklocalizzato in Preact:src/components/Link.tsxCopiare il codiceCopiare il codice nella clipboard
import { getLocalizedUrl } from "intlayer"; import { useLocale } from "preact-intlayer"; import { forwardRef } from "preact/compat"; import type { JSX } from "preact"; export interface LinkProps extends JSX.HTMLAttributes<HTMLAnchorElement> { href: string; } /** * Funzione di utilità per verificare se un URL dato è esterno. * Se l'URL inizia con http:// o https://, è 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 collegamenti interni, utilizza `getLocalizedUrl` per anteporre all'URL la lingua (ad esempio, /fr/about). * Questo garantisce che la navigazione rimanga all'interno dello stesso contesto linguistico. */ export const Link = forwardRef<HTMLAnchorElement, LinkProps>( ({ href, children, ...props }, ref) => { const { locale } = useLocale(); const isExternalLink = checkIsExternalLink(href); // Se il collegamento è interno e viene fornito un href valido, ottieni l'URL localizzato. const hrefI18n = href && !isExternalLink ? getLocalizedUrl(href, locale) : href; return ( <a href={hrefI18n} ref={ref} {...props}> {children} </a> ); } ); Link.displayName = "Link";Come Funziona
- Rilevamento dei collegamenti esterni:
La funzione di supportocheckIsExternalLinkdetermina se un URL è esterno. I collegamenti esterni rimangono invariati perché non necessitano di localizzazione. - Recupero della lingua corrente:
L'hookuseLocalefornisce la lingua corrente (ad esempio,frper il francese). - Localizzazione dell'URL:
Per i collegamenti interni (ovvero non esterni), viene utilizzatogetLocalizedUrlper anteporre automaticamente l'URL con la lingua corrente. Ciò significa che se il tuo utente è in francese, passare/aboutcomehreflo trasformerà in/fr/about. - Restituzione del collegamento:
Il componente restituisce un elemento<a>con l'URL localizzato, garantendo che la navigazione sia coerente con la lingua.
Rendering di Markdown e HTML
OpzionaleIntlayer supporta il rendering di contenuti Markdown e HTML in Preact.
Puoi personalizzare il rendering dei contenuti Markdown e HTML utilizzando il metodo
.use(). Questo metodo ti consente di sovrascrivere il rendering predefinito di tag specifici.tsxCopiare il codiceCopiare il codice nella clipboard
import { useIntlayer } from "preact-intlayer";const { myMarkdownContent, myHtmlContent } = useIntlayer("my-component");// ...return ( <div> {/* Rendering di base */} {myMarkdownContent} {/* Rendering personalizzato per Markdown */} {myMarkdownContent.use({ h1: (props) => <h1 style={{ color: "red" }} {...props} />, })} {/* Rendering di base per HTML */} {myHtmlContent} {/* Rendering personalizzato per HTML */} {myHtmlContent.use({ b: (props) => <strong style={{ color: "blue" }} {...props} />, })} </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
Configura TypeScript
Intlayer utilizza l'augmentation dei moduli per sfruttare i vantaggi di TypeScript e rendere la tua base di codice più robusta.


Assicurati che la tua configurazione TypeScript includa i tipi autogenerati.
Copiare il codice nella clipboard
{ // ... Le tue configurazioni TypeScript esistenti "compilerOptions": { // ... "jsx": "react-jsx", "jsxImportSource": "preact", // Consigliato per Preact 10+ // ... }, "include": [ // ... Le tue configurazioni TypeScript esistenti ".intlayer/**/*.ts", // Includi i tipi autogenerati ],}Assicurati che il tuotsconfig.jsonsia impostato per Preact, in particolarejsxejsxImportSourceoppurejsxFactory/jsxFragmentFactoryper versioni precedenti di Preact se non utilizzi i valori predefiniti dipreset-vite.
Configurazione Git
Si consiglia di ignorare i file generati da Intlayer. Ciò ti consente di evitare di committarli nel tuo repository Git.
Per farlo, puoi aggiungere le seguenti istruzioni al tuo file .gitignore:
Copiare il codice nella clipboard
# Ignora i file generati da Intlayer.intlayerEstensione VS Code
Per migliorare la tua esperienza di sviluppo con Intlayer, puoi installare l'estensione ufficiale Intlayer per VS Code.
Installa dal Marketplace di VS Code
Questa estensione offre:
- Autocompletamento per le chiavi di traduzione.
- Rilevamento degli errori in tempo reale per le traduzioni mancanti.
- Anteprime in linea del contenuto tradotto.
- Azioni rapide per creare e aggiornare facilmente le traduzioni.
Per maggiori dettagli su come utilizzare l'estensione, consulta la documentazione dell'estensione Intlayer per VS Code.
(Opzionale) Sitemap e robots.txt (generazione in build)
Intlayer espone utilità - generateSitemap e getMultilingualUrls - per formattare sitemap.xml multilingue e robots.txt pronti per i crawler e scriverli automaticamente in public/. Di solito si esegue un piccolo script Node prima di Vite (ad esempio hook npm predev / prebuild) così che i file siano presenti in build o in sviluppo.
Sitemap
Il generatore di sitemap di Intlayer rispetta le tue lingue e aggiunge i metadati attesi dai crawler.
La sitemap supporta lo spazio dei nomixhtml:link(hreflang). Invece di elencare solo URL “piatti”, Intlayer collega in modo bidirezionale tutte le versioni linguistiche di ogni pagina (ad es./about,/fr/abouto/about?lang=fra seconda del routing).
Robots.txt
Usa getMultilingualUrls così le regole Disallow coprono tutte le varianti localizzate dei percorsi sensibili.
1. Aggiungi generate-seo.mjs nella root del progetto
Copiare il codice nella clipboard
import fs from "fs";import path from "path";import { fileURLToPath } from "url";import { generateSitemap, getMultilingualUrls } from "intlayer";const __dirname = path.dirname(fileURLToPath(import.meta.url));const SITE_URL = (process.env.SITE_URL || "http://localhost:5173").replace( /\/$/, "");const pathList = [ { path: "/", changefreq: "daily", priority: 1.0 }, { path: "/about", changefreq: "monthly", priority: 0.7 },];const sitemapXml = generateSitemap(pathList, { siteUrl: SITE_URL });fs.writeFileSync(path.join(__dirname, "public", "sitemap.xml"), sitemapXml);const getAllMultilingualUrls = (urls) => urls.flatMap((url) => Object.values(getMultilingualUrls(url)));const disallowedPaths = getAllMultilingualUrls(["/admin", "/private"]);const robotsTxt = [ "User-agent: *", "Allow: /", ...disallowedPaths.map((path) => `Disallow: ${path}`), "", `Sitemap: ${SITE_URL}/sitemap.xml`,].join("\n");fs.writeFileSync(path.join(__dirname, "public", "robots.txt"), robotsTxt);console.log("SEO files generated successfully.");Serve il pacchetto intlayer installato. Imposta SITE_URL in ambiente per la produzione (es. in CI).
Preferiscigenerate-seo.mjsper l’ESM di Node. Congenerate-seo.jsimposta"type": "module"inpackage.jsonoppure abilita l’ESM in Node.
2. Esegui lo script prima di Vite
Copiare il codice nella clipboard
{ "scripts": { "dev": "vite", "prebuild": "node generate-seo.mjs", "build": "vite build", "preview": "vite preview" }}Adatta i comandi se usi pnpm o yarn. Puoi anche richiamare lo script dalla CI o da un altro passo del pipeline.
Andare oltre
Per andare oltre, puoi implementare l’editor visuale o esternalizzare i tuoi contenuti utilizzando il CMS.