Posez votre question et obtenez un résumé du document en referencant cette page et le Provider AI de votre choix
Historique des versions
- "Mettre à jour l'utilisation de l'API useIntlayer de Solid pour un accès direct aux propriétés"v8.9.004/05/2026
- "Ajouté pour Tanstack Start Solid.js"v8.5.125/03/2026
Le contenu de cette page a été traduit à l'aide d'une IA.
Voir la dernière version du contenu original en anglaisIf 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
Traduisez votre site web Tanstack Start avec Solid.js en utilisant Intlayer | Internationalisation (i18n)
Table des matières
Ce guide démontre comment intégrer Intlayer pour une internationalisation fluide dans les projets Tanstack Start avec Solid.js, le routage tenant compte de la localisation, le support TypeScript et les pratiques de développement modernes.
Pourquoi Intlayer plutôt que des alternatives ?
Par rapport aux solutions principales telles que react-i18next ou i18next, Intlayer est une solution dotée d'optimisations intégrées telles que :
Intlayer est optimisé pour fonctionner parfaitement avec TanStack Start et Solid en offrant un routage multilingue, un plan du site et toutes les fonctionnalités nécessaires à la mise à l'échelle de l'internationalisation (i18n).
Au lieu de charger de lourds fichiers JSON dans vos pages, ne chargez que le contenu strictement nécessaire. Intlayer vous aide à réduire la taille de votre bundle et de vos pages jusqu'à 50 %.
Déclarer le contenu directement au plus près de vos composants facilite la maintenance des applications de grande envergure. Vous pouvez dupliquer ou supprimer le dossier d'une fonctionnalité sans le fardeau mental de devoir passer en revue toute votre base de code de contenu. De plus, Intlayer est entièrement typé pour garantir l'exactitude de vos traductions.
La colocalisation du contenu réduit le contexte nécessaire aux grands modèles de langage (LLM). Intlayer est également livré avec une suite d'outils, tels qu'une CLI pour vérifier les traductions manquantes, un LSP, un MCP et des agent skills, afin de rendre l'expérience développeur (DX) encore plus fluide pour les agents IA.
Automatisez les traductions dans votre pipeline CI/CD en utilisant le LLM de votre choix au coût de votre propre fournisseur d'IA. Intlayer propose également un compilateur pour automatiser l'extraction de contenu, ainsi qu'une plateforme web pour vous aider à traduire en arrière-plan.
Associer de gros fichiers JSON à vos composants peut ralentir les performances et impacter la réactivité. Intlayer optimise le chargement du contenu directement au moment du build.
Bien plus qu'une simple solution i18n, Intlayer propose un éditeur visuel auto-hébergé et un CMS complet pour gérer votre contenu multilingue en temps réel. Cela rend la collaboration avec les traducteurs, concepteurs-rédacteurs et autres membres de l'équipe extrêmement simple. Le contenu peut être stocké localement et/ou à distance.
Guide étape par étape pour configurer Intlayer dans une application Tanstack Start
Voir le Modèle d'Application sur GitHub.
Créer le projet
Commencez par créer un nouveau projet TanStack Start en suivant le guide Démarrer un nouveau projet sur le site web de TanStack Start.
Installer les packages Intlayer
Installez les packages nécessaires en utilisant votre gestionnaire de paquets préféré :
bashCopier le codeCopier le code dans le presse-papiers
npm install intlayer solid-intlayernpm install vite-intlayer --save-devnpx intlayer initintlayer
Le package principal qui fournit des outils d'internationalisation pour la gestion de la configuration, la traduction, la déclaration de contenu, la transpilation et les commandes CLI.
solid-intlayer Le package qui intègre Intlayer avec une application Solid. Il fournit des fournisseurs de contexte et des hooks pour l'internationalisation Solid.
vite-intlayer Inclut le plugin Vite pour intégrer Intlayer avec le bundler Vite, ainsi qu'un middleware pour détecter la langue préférée de l'utilisateur, gérer les cookies et gérer la redirection d'URL.
Configuration de votre projet
Créez un fichier de configuration pour configurer les langues de votre application :
intlayer.config.tsCopier le codeCopier le code dans le presse-papiers
import type { IntlayerConfig } from "intlayer";import { Locales } from "intlayer";const config: IntlayerConfig = { internationalization: { defaultLocale: Locales.ENGLISH, locales: [Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH], },};export default config;Grâce à ce fichier de configuration, vous pouvez configurer des URL localisées, la redirection du middleware, les noms des cookies, l'emplacement et l'extension de vos déclarations de contenu, désactiver les logs Intlayer dans la console, et plus encore. Pour une liste complète des paramètres disponibles, reportez-vous à la documentation de configuration.
Intégrer Intlayer dans votre configuration Vite
Ajoutez le plugin intlayer dans votre configuration :
vite.config.tsCopier le codeCopier le code dans le presse-papiers
import { intlayer } from "vite-intlayer";import { defineConfig } from "vite";import { devtools } from "@tanstack/devtools-vite";import { tanstackStart } from "@tanstack/solid-start/plugin/vite";import solidPlugin from "vite-plugin-solid";export default defineConfig({ plugins: [ devtools(), tanstackStart({ router: { routeFileIgnorePattern: ".content.(ts|tsx|js|mjs|cjs|jsx|json|jsonc|json5)$", }, }), solidPlugin({ ssr: true }), intlayer(), ],});Le plugin Vite
intlayer()est utilisé pour intégrer Intlayer avec Vite. Il assure la construction des fichiers de déclaration de contenu et les surveille en mode développement. Il définit les variables d'environnement Intlayer au sein de l'application Vite. De plus, il fournit des alias pour optimiser les performances.Créer l'affichage racine
Configurez votre affichage racine pour supporter l'internationalisation en utilisant
useParamspour détecter la langue actuelle et en définissant les attributslangetdirsur la balisehtml.src/routes/__root.tsxCopier le codeCopier le code dans le presse-papiers
import { HeadContent, Scripts, createRootRouteWithContext,} from "@tanstack/solid-router";import { HydrationScript } from "solid-js/web";import { Suspense, type ParentComponent } from "solid-js";import { IntlayerProvider } from "solid-intlayer";import { defaultLocale, getHTMLTextDir } from "intlayer";import { Route as LocaleRoute } from "./{-$locale}/route";export const Route = createRootRouteWithContext()({ shellComponent: RootComponent,});const RootComponent: ParentComponent = (props) => { const params = LocaleRoute.useParams(); const locale = params()?.locale ?? defaultLocale; return ( <html dir={getHTMLTextDir(locale)} lang={locale}> <head> <HydrationScript /> <HeadContent /> </head> <body> <IntlayerProvider locale={locale}> <Suspense>{props.children}</Suspense> </IntlayerProvider> <Scripts /> </body> </html> );};Créer la mise en page de la langue
Créez une mise en page qui gère le préfixe de la langue et effectue la validation. Cette mise en page garantira que seules les langues valides sont traitées.
Cette étape est facultative si vous n'avez pas besoin de valider le préfixe de la langue au niveau de la route.
src/routes/{-$locale}/route.tsxCopier le codeCopier le code dans le presse-papiers
import { createFileRoute, Outlet, redirect } from "@tanstack/solid-router";import { validatePrefix } from "intlayer";export const Route = createFileRoute("/{-$locale}")({ beforeLoad: ({ params }) => { const localeParam = params.locale; // Valider le préfixe de la langue const { isValid, localePrefix } = validatePrefix(localeParam); if (!isValid) { throw redirect({ to: "/{-$locale}/404", params: { locale: localePrefix }, replace: true, }); } }, component: Outlet,});Ici,
{-$locale}est un paramètre de route dynamique qui est remplacé par la langue actuelle. Cette notation rend le segment optionnel, lui permettant de fonctionner avec des modes de routage tels que'prefix-no-default', etc.Sachez que ce segment peut causer des problèmes si vous utilisez plusieurs segments dynamiques dans la même route (par exemple,
/{-$locale}/autre-chemin/$unAutreCheminDynamique/...). Pour le mode'prefix-all', vous préférerez peut-être remplacer le segment par$locale. Pour le mode'no-prefix'ou'search-params', vous pouvez supprimer complètement le segment.Déclarer votre contenu
Créez et gérez vos déclarations de contenu pour stocker les traductions :
src/contents/page.content.tsCopier le codeCopier le code dans le presse-papiers
import type { Dictionary } from "intlayer";import { t } from "intlayer";const appContent = { content: { links: { about: t({ en: "About", es: "Acerca de", fr: "À propos", }), home: t({ en: "Home", es: "Inicio", fr: "Accueil", }), }, meta: { title: t({ en: "Welcome to Intlayer + TanStack Router", es: "Bienvenido a Intlayer + TanStack Router", fr: "Bienvenue à Intlayer + TanStack Router", }), description: t({ en: "This is an example of using Intlayer with TanStack Router", es: "Este es un exemple de uso de Intlayer con TanStack Router", fr: "Ceci est un exemple d'utilisation d'Intlayer avec TanStack Router", }), }, }, key: "app",} satisfies Dictionary;export default appContent;Vos déclarations de contenu peuvent être définies n'importe où dans votre application tant qu'elles sont incluses dans le répertoire
contentDir(par défaut,./app). Et qu'elles correspondent à l'extension du fichier de déclaration de contenu (par défaut,.content.{json,ts,tsx,js,jsx,mjs,cjs,md,mdx,yaml,yml}).Pour plus de détails, reportez-vous à la documentation sur la déclaration de contenu.
Créer des composants et des hooks tenant compte de la langue
Créez un composant
LocalizedLinkpour une navigation tenant compte de la langue :src/components/LocalizedLink.tsxCopier le codeCopier le code dans le presse-papiers
import { Link, type LinkProps } from "@tanstack/solid-router";import { getPrefix } from "intlayer";import { useLocale } from "solid-intlayer";import type { JSX } from "solid-js";export const LOCALE_ROUTE = "{-$locale}" as const;export type RemoveLocaleParam<TVal> = TVal extends string ? RemoveLocaleFromString<TVal> : TVal;export type To = RemoveLocaleParam<LinkProps["to"]>;type CollapseDoubleSlashes<TString extends string> = TString extends `${infer THead}//${infer TTail}` ? CollapseDoubleSlashes<`${THead}/${TTail}`> : TString;export type LocalizedLinkProps = Omit<LinkProps, "to"> & { to?: To;} & JSX.AnchorHTMLAttributes<HTMLAnchorElement>;type RemoveAll< TString extends string, TSub extends string,> = TString extends `${infer THead}${TSub}${infer TTail}` ? RemoveAll<`${THead}${TTail}`, TSub> : TString;type RemoveLocaleFromString<TString extends string> = CollapseDoubleSlashes< RemoveAll<TString, typeof LOCALE_ROUTE>>;export const LocalizedLink = (props: LocalizedLinkProps) => { const { locale } = useLocale(); return ( <Link {...props} params={{ locale: getPrefix(locale()).localePrefix, ...(typeof props.params === "object" ? props.params : {}), }} to={`/${LOCALE_ROUTE}${props.to ?? ""}` as LinkProps["to"]} /> );};Ce composant a deux objectifs :
- Supprimer le préfixe inutile
{-$locale}de l'URL. - Injecter le paramètre de langue dans l'URL pour garantir que l'utilisateur est directement redirigé vers la route localisée.
Ensuite, nous pouvons créer un hook
useLocalizedNavigatepour la navigation programmatique :src/hooks/useLocalizedNavigate.tsxCopier le codeCopier le code dans le presse-papiers
import { useNavigate } from "@tanstack/solid-router";import { getLocalizedUrl } from "intlayer";import { useLocale } from "solid-intlayer";export const useLocalizedNavigate = () => { const navigate = useNavigate(); const { locale } = useLocale(); const localizedNavigate = (to: string) => { const localizedTo = getLocalizedUrl(to, locale()); return navigate({ to: localizedTo }); }; return localizedNavigate;};- Supprimer le préfixe inutile
Utiliser Intlayer dans vos pages
Accédez à vos dictionnaires de contenu partout dans votre application :
Page d'accueil localisée
src/routes/{-$locale}/index.tsxCopier le codeCopier le code dans le presse-papiers
import { createFileRoute } from "@tanstack/solid-router";import { useIntlayer } from "solid-intlayer";import { LocalizedLink } from "@/components/LocalizedLink";export const Route = createFileRoute("/{-$locale}/")({ component: RouteComponent,});function RouteComponent() { const content = useIntlayer("index-page"); return ( <main> <h1>{content.heroTitle}</h1> <p>{content.heroDesc}</p> <div> <LocalizedLink to="/">{content.navHome}</LocalizedLink> <LocalizedLink to="/about">{content.navAbout}</LocalizedLink> </div> </main> );}Dans Solid,
useIntlayerretourne un contenu réactif (par exemple,content). Vous pouvez accéder directement à ses propriétés.Si vous souhaitez utiliser votre contenu dans un attribut de type
string, tel quealt,title,href,aria-label, etc., vous devez appeler la valeur de la fonction, comme ceci :htmlCopier le codeCopier le code dans le presse-papiers
<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)}" />Pour en savoir plus sur le hook
useIntlayer, reportez-vous à la documentation.Créer un composant de changement de langue
Créez un composant pour permettre aux utilisateurs de changer de langue :
src/components/LocaleSwitcher.tsxCopier le codeCopier le code dans le presse-papiers
import { useLocation } from "@tanstack/solid-router";import { getLocaleName, getPathWithoutLocale, getPrefix } from "intlayer";import { For } from "solid-js";import { useIntlayer, useLocale } from "solid-intlayer";import { LocalizedLink, type To } from "./LocalizedLink";export const LocaleSwitcher = () => { const content = useIntlayer("locale-switcher"); const location = useLocation(); const { availableLocales, locale, setLocale } = useLocale(); const pathWithoutLocale = () => getPathWithoutLocale(location().pathname); return ( <div class="flex flex-row gap-2"> <For each={availableLocales}> {(localeEl) => ( <LocalizedLink aria-current={localeEl === locale() ? "page" : undefined} onClick={() => setLocale(localeEl)} params={{ locale: getPrefix(localeEl).localePrefix }} to={pathWithoutLocale() as To} > {getLocaleName(localeEl)} </LocalizedLink> )} </For> </div> );};export default LocaleSwitcher;Dans Solid,
localeprovenant deuseLocaleest un accesseur de signal. Utilisezlocale()(avec parenthèses) pour lire sa valeur actuelle de manière réactive.Pour en savoir plus sur le hook
useLocale, reportez-vous à la documentation.Gestion des attributs HTML
Comme vu à l'étape 5, vous pouvez gérer les attributs
langetdirde la balisehtmlen utilisantuseParamsdans votre composant racine. Cela garantit que les attributs corrects sont définis sur le serveur et le client.src/routes/__root.tsxCopier le codeCopier le code dans le presse-papiers
const RootComponent: ParentComponent = (props) => { const params = LocaleRoute.useParams(); const locale = params()?.locale ?? defaultLocale; return ( <html dir={getHTMLTextDir(locale)} lang={locale}> {/* ... */} </html> );};Ajouter un middleware
Vous pouvez également utiliser
intlayerProxypour ajouter un routage côté serveur à votre application. Ce plugin détectera automatiquement la langue actuelle en fonction de l'URL et définira le cookie de langue approprié. Si aucune langue n'est spécifiée, le plugin déterminera la langue la plus appropriée en fonction des préférences linguistiques du navigateur de l'utilisateur. Si aucune langue n'est détectée, il redirigera vers la langue par défaut.Notez que pour utiliser
intlayerProxyen production, vous devez déplacer le packagevite-intlayerdedevDependenciesversdependencies.vite.config.tsCopier le codeCopier le code dans le presse-papiers
import { tanstackStart } from "@tanstack/solid-start/plugin/vite";import solid from "vite-plugin-solid";import { nitro } from "nitro/vite";import { defineConfig } from "vite";import { intlayer, intlayerProxy } from "vite-intlayer";export default defineConfig({ plugins: [ intlayerProxy(), // Le proxy doit être placé avant le serveur si vous utilisez Nitro nitro(), intlayer(), tanstackStart({ router: { routeFileIgnorePattern: ".content.(ts|tsx|js|mjs|cjs|jsx|json|jsonc|json5)$", }, }), solid(), ],});Internationaliser vos métadonnées
Vous pouvez également utiliser la fonction
getIntlayerpour accéder à vos dictionnaires de contenu à l'intérieur du chargeurheadpour des métadonnées tenant compte de la localisation :src/routes/{-$locale}/index.tsxCopier le codeCopier le code dans le presse-papiers
import { createFileRoute } from "@tanstack/solid-router";import { getIntlayer } from "intlayer";export const Route = createFileRoute("/{-$locale}/")({ component: RouteComponent, head: ({ params }) => { const { locale } = params; const path = "/"; // The path for this route const metaContent = getIntlayer("app", locale); return { links: [ // Canonical link: Points to the current localized page { rel: "canonical", href: getLocalizedUrl(path, locale) }, // Hreflang: Tell Google about all localized versions ...localeMap(({ locale: mapLocale }) => ({ rel: "alternate", hrefLang: mapLocale, href: getLocalizedUrl(path, mapLocale), })), // x-default: For users in unmatched languages // Define the default fallback locale (usually your primary language) { rel: "alternate", hrefLang: "x-default", href: getLocalizedUrl(path, defaultLocale), }, ], meta: [ { title: metaContent.title }, { name: "description", content: metaContent.meta.description }, ], }; },});Récupérer la langue dans vos actions serveur
Vous voudrez peut-être accéder à la langue actuelle depuis vos actions serveur ou vos points de terminaison d'API. Vous pouvez le faire en utilisant l'utilitaire
getLocaled'intlayer.Voici un exemple utilisant les fonctions serveur de TanStack Start :
src/routes/{-$locale}/index.tsxCopier le codeCopier le code dans le presse-papiers
import { createServerFn } from "@tanstack/solid-start";import { getRequestHeader, getRequestHeaders,} from "@tanstack/solid-start/server";import { getCookie, getIntlayer, getLocale } from "intlayer";export const getLocaleServer = createServerFn().handler(async () => { const locale = await getLocale({ // Récupérer le cookie de la requête (par défaut : 'INTLAYER_LOCALE') getCookie: (name) => { const cookieString = getRequestHeader("cookie"); return getCookie(name, cookieString); }, // Récupérer l'en-tête de la requête (par défaut : 'x-intlayer-locale') // Repli en utilisant la négociation Accept-Language getHeader: (name) => getRequestHeader(name), }); // Récupérer du contenu en utilisant getIntlayer() const content = getIntlayer("app", locale); return { locale, content };});Gérer les pages non trouvées
Lorsqu'un utilisateur visite une page inexistante, vous pouvez afficher une page 404 personnalisée et le préfixe de langue peut impacter la manière dont la page non trouvée est déclenchée.
Comprendre la gestion 404 de TanStack Router avec les préfixes de langue
Dans TanStack Router, la gestion des pages 404 avec des routes localisées nécessite une approche à plusieurs niveaux :
- Route 404 dédiée : Une route spécifique pour afficher l'interface 404.
- Validation au niveau de la route : Valide les préfixes de langue et redirige les préfixes invalides vers la page 404.
- Route fourre-tout (Catch-all) : Capture tous les chemins non correspondants à l'intérieur du segment de langue.
src/routes/{-$locale}/404.tsxCopier le codeCopier le code dans le presse-papiers
import { createFileRoute } from "@tanstack/solid-router";// Cela crée une route dédiée /[locale]/404// Elle est utilisée à la fois comme route directe et importée en tant que composant dans d'autres fichiersexport const Route = createFileRoute("/{-$locale}/404")({ component: NotFoundComponent,});// Exporté séparément pour pouvoir être réutilisé dans notFoundComponent et les routes fourre-toutexport function NotFoundComponent() { return ( <div> <h1>404</h1> </div> );}src/routes/{-$locale}/route.tsxCopier le codeCopier le code dans le presse-papiers
import { createFileRoute, Outlet, redirect } from "@tanstack/solid-router";import { validatePrefix } from "intlayer";import { NotFoundComponent } from "./404";export const Route = createFileRoute("/{-$locale}")({ // beforeLoad s'exécute avant le rendu de la route (sur le serveur et le client) // C'est l'endroit idéal pour valider le préfixe de langue beforeLoad: ({ params }) => { const localeParam = params.locale; // validatePrefix vérifie si la langue est valide selon votre configuration intlayer const { isValid, localePrefix } = validatePrefix(localeParam); if (!isValid) { // Préfixe de langue invalide - rediriger vers la page 404 avec un préfixe de langue valide throw redirect({ to: "/{-$locale}/404", params: { locale: localePrefix }, }); } }, component: Outlet, // notFoundComponent est appelé lorsqu'une route enfant n'existe pas // par exemple, /en/page-inexistante déclenche cela à l'intérieur de la mise en page /en notFoundComponent: NotFoundComponent,});src/routes/{-$locale}/$.tsxCopier le codeCopier le code dans le presse-papiers
import { createFileRoute } from "@tanstack/solid-router";import { NotFoundComponent } from "./404";// La route $ (splat/catch-all) correspond à n'importe quel chemin qui ne correspond pas aux autres routes// par exemple, /en/certains/chemins/profondément/imbriqués/invalides// Cela garantit que TOUS les chemins non correspondants à l'intérieur d'une langue affichent la page 404// Sans cela, les chemins profonds non correspondants pourraient afficher une page blanche ou une erreurexport const Route = createFileRoute("/{-$locale}/$")({ component: NotFoundComponent,});Extraire le contenu de vos composants
FacultatifSi vous avez une base de code existante, transformer des milliers de fichiers peut prendre du temps.
Pour faciliter ce processus, Intlayer propose un compilateur / extracteur pour transformer vos composants et extraire le contenu.
Pour le configurer, vous pouvez ajouter une section
compilerdans votre fichierintlayer.config.ts:intlayer.config.tsCopier le codeCopier le code dans le presse-papiers
import { type IntlayerConfig } from "intlayer"; const config: IntlayerConfig = { // ... Reste de votre config compiler: { /** * Indique si le compilateur doit être activé. */ enabled: true, /** * Définit le chemin des fichiers de sortie */ output: ({ fileName, extension }) => `./${fileName}${extension}`, /** * Indique si les composants doivent être enregistrés après avoir été transformés. * * - Si `true`, le compilateur réécrira le fichier du composant sur le disque. Ainsi, la transformation sera permanente, et le compilateur ignorera la transformation pour le prochain processus. De cette façon, le compilateur peut transformer l'application, puis il peut être supprimé. * * - Si `false`, le compilateur injectera l'appel de fonction `useIntlayer()` dans le code de la sortie de construction uniquement, et gardera la base de code intacte. La transformation se fera uniquement en mémoire. */ saveComponents: false, /** * Préfixe de clé de dictionnaire */ dictionaryKeyPrefix: "", }, }; export default config;Exécutez l'extracteur pour transformer vos composants et extraire le contenu
bashCopier le codeCopier le code dans le presse-papiers
npx intlayer extractGénérer un Sitemap
Intlayer est livré avec un générateur de sitemap intégré pour vous aider à créer facilement un sitemap pour votre application. Il gère les routes localisées et ajoute les métadonnées nécessaires pour les moteurs de recherche.
Le sitemap généré par Intlayer prend en charge l'espace de noms
xhtml:link(Hreflang XML Extensions). Contrairement aux générateurs de sitemap par défaut qui ne répertorient que les URL brutes, Intlayer crée automatiquement les liens bidirectionnels requis entre toutes les versions linguistiques d'une page (par exemple,/about,/about?lang=fret/about?lang=es). Cela garantit que les moteurs de recherche indexent et servent correctement la bonne version linguistique au bon public.Pour l'utiliser, vous devez d'abord configurer votre fichier
vite.config.tspour activer le pré-rendu de vos routes localisées et désactiver la génération de sitemap par défaut de TanStack Start.vite.config.tsCopier le codeCopier le code dans le presse-papiers
import { localeMap, localeFlatMap } from "intlayer";// ... autres importsexport const pathList = ["", "/about", "/404"];const localizedPages = localeFlatMap(({ urlPrefix }) => pathList.map((path) => ({ path: `${urlPrefix}${path}`, prerender: { enabled: true, }, })));export default defineConfig({ plugins: [ // ... autres plugins tanstackStart({ // ... autres configurations sitemap: { enabled: false, }, prerender: { enabled: true, crawlLinks: false, concurrency: 10, }, pages: localizedPages, }), ],});Ensuite, créez une route
src/routes/sitemap[.]xml.tsqui utilise la fonctiongenerateSitemap:src/routes/sitemap[.]xml.tsCopier le codeCopier le code dans le presse-papiers
import { createFileRoute } from "@tanstack/solid-router";import { generateSitemap } from "intlayer";const SITE_URL = "http://localhost:3000";export const Route = createFileRoute("/sitemap.xml")({ server: { handlers: { GET: async () => { const sitemap = generateSitemap( [ { path: "/", changefreq: "daily", priority: 1.0 }, { path: "/about", changefreq: "monthly", priority: 0.8 }, ], { siteUrl: SITE_URL } ); return new Response(sitemap, { headers: { "Content-Type": "application/xml" }, }); }, }, },});Configurer TypeScript
Intlayer utilise l'augmentation de module pour bénéficier des avantages de TypeScript et rendre votre base de code plus robuste.
Assurez-vous que votre configuration TypeScript inclut les types autogénérés :
tsconfig.jsonCopier le codeCopier le code dans le presse-papiers
{ // ... vos configurations existantes include: [ // ... vos inclusions existantes ".intlayer/**/*.ts", // Inclure les types auto-générés ],}
Configuration Git
Il est recommandé d'ignorer les fichiers générés par Intlayer. Cela vous permet d'éviter de les commettre dans votre dépôt Git.
Pour ce faire, vous pouvez ajouter les instructions suivantes à votre fichier .gitignore :
Copier le code dans le presse-papiers
# Ignorer les fichiers générés par Intlayer.intlayerExtension VS Code
Pour améliorer votre expérience de développement avec Intlayer, vous pouvez installer l'extension officielle Intlayer VS Code.
Installer depuis le VS Code Marketplace
Cette extension fournit :
- Autocomplétion pour les clés de traduction.
- Détection des erreurs en temps réel pour les traductions manquantes.
- Aperçus en ligne du contenu traduit.
- Actions rapides pour créer et mettre à jour facilement les traductions.
Pour plus de détails sur l'utilisation de l'extension, reportez-vous à la documentation de l'extension Intlayer VS Code.
Aller plus loin
Pour aller plus loin, vous pouvez implémenter l'éditeur visuel ou externaliser votre contenu en utilisant le CMS.