--- createdAt: 2024-08-11 updatedAt: 2026-05-31 title: "Create React App i18n - Guide complet pour traduire votre application" description: "Oubliez i18next. Le guide 2026 pour créer une application Create React App multilingue (i18n). Traduisez avec des agents IA et optimisez la taille du bundle, le SEO et les performances." keywords: - Internationalisation - Documentation - Intlayer - Create React App - CRA - JavaScript - React slugs: - doc - environment - create-react-app applicationTemplate: https://github.com/aymericzip/intlayer-react-cra-template history: - version: 8.9.0 date: 2026-05-04 changes: "Mettre à jour l'utilisation de l'API useIntlayer de Solid pour un accès direct aux propriétés" - version: 7.5.9 date: 2025-12-30 changes: "Ajouter la commande init" - version: 5.5.10 date: 2025-06-29 changes: "Historique initial" --- # Traduire votre Create React App avec Intlayer | Internationalisation (i18n) Voir [Application Template](https://github.com/aymericzip/intlayer-react-cra-template) sur GitHub. ## Qu'est-ce qu'Intlayer ? **Intlayer** est une bibliothèque open-source innovante d'internationalisation (i18n) conçue pour simplifier la prise en charge multilingue dans les applications web modernes. Avec Intlayer, vous pouvez : - **Gérer facilement les traductions** en utilisant des dictionnaires déclaratifs au niveau des composants. - **Localiser dynamiquement les métadonnées**, les routes et le contenu. - **Assurer la prise en charge de TypeScript** avec des types générés automatiquement, améliorant l'autocomplétion et la détection des erreurs. - **Bénéficier de fonctionnalités avancées**, comme la détection et le changement dynamiques de locale. ## Guide étape par étape pour configurer Intlayer dans une application React Installez les packages nécessaires en utilisant npm : ```bash packageManager="npm" npm install intlayer react-intlayer react-scripts-intlayer npx intlayer init ``` ```bash packageManager="pnpm" pnpm add intlayer react-intlayer react-scripts-intlayer pnpm intlayer init ``` ```bash packageManager="yarn" yarn add intlayer react-intlayer react-scripts-intlayer yarn intlayer init ``` ```bash packageManager="bun" bun add intlayer react-intlayer react-scripts-intlayer bun x intlayer init ``` - **intlayer** Le package principal qui fournit des outils d'internationalisation pour la gestion de configuration, la traduction, [la déclaration de contenu](https://github.com/aymericzip/intlayer/blob/main/docs/docs/fr/dictionary/content_file.md), la transpilation et les [commandes CLI](https://github.com/aymericzip/intlayer/blob/main/docs/docs/fr/cli/index.md). - **react-intlayer** Le package qui intègre Intlayer avec une application React. Il fournit des fournisseurs de contexte et des hooks pour l'internationalisation dans React. - **react-scripts-intlayer** Inclut les commandes et plugins `react-scripts-intlayer` pour intégrer Intlayer avec une application basée sur Create React App. Ces plugins sont basés sur [craco](https://craco.js.org/) et incluent une configuration supplémentaire pour le bundler [Webpack](https://webpack.js.org/). Créez un fichier de configuration pour configurer les langues de votre application : ```typescript fileName="intlayer.config.ts" codeFormat={["typescript", "esm", "commonjs"]} import { Locales, type IntlayerConfig } from "intlayer"; const config: IntlayerConfig = { internationalization: { locales: [ Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH, // Vos autres locales ], defaultLocale: Locales.ENGLISH, }, }; export default config; ``` > Grâce à ce fichier de configuration, vous pouvez configurer des URL localisées, des redirections middleware, des noms de 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, consultez la [documentation de configuration](https://github.com/aymericzip/intlayer/blob/main/docs/docs/fr/configuration.md). Modifiez vos scripts pour utiliser react-intlayer ```json fileName="package.json" "scripts": { "build": "react-scripts-intlayer build", "start": "react-scripts-intlayer start", "transpile": "intlayer build" }, ``` > Les scripts `react-scripts-intlayer` sont basés sur [CRACO](https://craco.js.org/). Vous pouvez également implémenter votre propre configuration basée sur le plugin craco d'intlayer. [Voir un exemple ici](https://github.com/aymericzip/intlayer/blob/main/examples/react-app/craco.config.js). Créez et gérez vos déclarations de contenu pour stocker les traductions : ```tsx fileName="src/app.content.tsx" codeFormat={["typescript", "esm"]} import { t, type Dictionary } from "intlayer"; import React, { type ReactNode } from "react"; const appContent = { key: "app", content: { getStarted: t({ en: ( <> Edit src/App.tsx and save to reload ), fr: ( <> Éditez src/App.tsx et enregistrez pour recharger ), es: ( <> Edita src/App.tsx y guarda para recargar ), }), reactLink: { href: "https://reactjs.org", content: t({ en: "Learn React", fr: "Apprendre React", es: "Aprender React", }), }, }, } satisfies Dictionary; export default appContent; ``` > Vos déclarations de contenu peuvent être définies n'importe où dans votre application dès qu'elles sont incluses dans le répertoire `contentDir` (par défaut, `./src`). Et correspondent à l'extension de 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, consultez la [documentation sur les déclarations de contenu](https://github.com/aymericzip/intlayer/blob/main/docs/docs/fr/dictionary/content_file.md). > Si votre fichier de contenu inclut du code TSX, vous devriez envisager d'importer `import React from "react";` dans votre fichier de contenu. Accédez à vos dictionnaires de contenu dans toute votre application : ```tsx {4,7} fileName="src/App.tsx" codeFormat={["typescript", "esm"]} import logo from "./logo.svg"; import "./App.css"; import type { FC } from "react"; import { IntlayerProvider, useIntlayer } from "react-intlayer"; const AppContent: FC = () => { const content = useIntlayer("app"); return (
logo {content.getStarted} {content.reactLink.content}
); }; const App: FC = () => ( ); export default App; ``` > Remarque : Si vous souhaitez utiliser votre contenu dans un attribut `string`, tel que `alt`, `title`, `href`, `aria-label`, etc., vous devez appeler la valeur de la fonction, comme : > ```html > {content.image.value} > {content.image.toString()} > {String(content.image)} > ``` > > Pour en savoir plus sur le hook `useIntlayer`, consultez la [documentation](https://github.com/aymericzip/intlayer/blob/main/docs/docs/fr/packages/react-intlayer/useIntlayer.md).
Pour changer la langue de votre contenu, vous pouvez utiliser la fonction `setLocale` fournie par le hook `useLocale`. Cette fonction vous permet de définir la locale de l'application et de mettre à jour le contenu en conséquence. ```tsx fileName="src/components/LocaleSwitcher.tsx" codeFormat={["typescript", "esm"]} import { Locales } from "intlayer"; import { useLocale } from "react-intlayer"; const LocaleSwitcher = () => { const { setLocale } = useLocale(); return ( ); }; ``` > Pour en savoir plus sur le hook `useLocale`, consultez la [documentation](https://github.com/aymericzip/intlayer/blob/main/docs/docs/fr/packages/react-intlayer/useLocale.md). L'objectif de cette étape est de créer des routes uniques pour chaque langue. Cela est utile pour le SEO et les URL conviviales pour les moteurs de recherche. Exemple : ```plaintext - https://example.com/about - https://example.com/es/about - https://example.com/fr/about ``` > Par défaut, les routes ne sont pas préfixées pour la locale par défaut. Si vous souhaitez préfixer la locale par défaut, vous pouvez définir l'option `middleware.prefixDefault` sur `true` dans votre configuration. Consultez la [documentation de configuration](https://github.com/aymericzip/intlayer/blob/main/docs/docs/fr/configuration.md) pour plus d'informations. Pour ajouter un routage localisé à votre application, vous pouvez créer un composant `LocaleRouter` qui enveloppe les routes de votre application et gère le routage basé sur la locale. Voici un exemple utilisant [React Router](https://reactrouter.com/home): ```tsx fileName="src/components/LocaleRouter.tsx" codeFormat={["typescript", "esm"]} // Importation des dépendances nécessaires et des fonctions import { type Locales, configuration, getPathWithoutLocale } from "intlayer"; // Fonctions utilitaires et types d'intlayer import type { FC, PropsWithChildren } from "react"; // Types React pour les composants fonctionnels et les props import { IntlayerProvider } from "react-intlayer"; // Fournisseur pour le contexte d'internationalisation import { BrowserRouter, Routes, Route, Navigate, useLocation, } from "react-router-dom"; // Composants de routage pour gérer la navigation // Déstructuration de la configuration depuis Intlayer const { internationalization, middleware } = configuration; const { locales, defaultLocale } = internationalization; /** * Un composant qui gère la localisation et enveloppe les enfants avec le contexte de locale approprié. * Il gère la détection et la validation basées sur l'URL. */ const AppLocalized: FC> = ({ children, locale, }) => { const { pathname, search } = useLocation(); // Obtenez le chemin URL actuel // Déterminez la locale actuelle, en revenant à la locale par défaut si elle n'est pas fournie const currentLocale = locale ?? defaultLocale; // Supprimez le préfixe de locale du chemin pour construire un chemin de base const pathWithoutLocale = getPathWithoutLocale( pathname // Chemin URL actuel ); /** * Si middleware.prefixDefault est vrai, la locale par défaut doit toujours être préfixée. */ if (middleware.prefixDefault) { // Validez la locale if (!locale || !locales.includes(locale)) { // Redirigez vers la locale par défaut avec le chemin mis à jour return ( ); } // Enveloppez les enfants avec le fournisseur Intlayer et définissez la locale actuelle return ( {children} ); } else { /** * Lorsque middleware.prefixDefault est faux, la locale par défaut n'est pas préfixée. * Assurez-vous que la locale actuelle est valide et n'est pas la locale par défaut. */ if ( currentLocale.toString() !== defaultLocale.toString() && !locales .filter( (locale) => locale.toString() !== defaultLocale.toString() // Excluez la locale par défaut ) .includes(currentLocale) // Vérifiez si la locale actuelle est dans la liste des locales valides ) { // Redirigez vers le chemin sans préfixe de locale return ; } // Enveloppez les enfants avec le fournisseur Intlayer et définissez la locale actuelle return ( {children} ); } }; /** * Un composant de routage qui configure des routes spécifiques à la locale. * Il utilise React Router pour gérer la navigation et rendre les composants localisés. */ export const LocaleRouter: FC = ({ children }) => ( {locales .filter( (locale) => middleware.prefixDefault || locale !== defaultLocale ) .map((locale) => ( {children}} // Enveloppe les enfants avec la gestion de la locale /> ))} { // Si le préfixage de la locale par défaut est désactivé, rendre les enfants directement à la racine !middleware.prefixDefault && ( {children} } // Enveloppe les enfants avec la gestion de la locale /> ) } ); ``` Ensuite, vous pouvez utiliser le composant `LocaleRouter` dans votre application : ```tsx fileName="src/App.tsx" codeFormat={["typescript", "esm"]} import { LocaleRouter } from "./components/LocaleRouter"; import type { FC } from "react"; // ... Votre composant AppContent const App: FC = () => ( ); ``` Pour modifier l'URL lorsque la locale change, vous pouvez utiliser la prop `onLocaleChange` fournie par le hook `useLocale`. En parallèle, vous pouvez utiliser les hooks `useLocation` et `useNavigate` de `react-router-dom` pour mettre à jour le chemin URL. ```tsx fileName="src/components/LocaleSwitcher.tsx" codeFormat={["typescript", "esm"]} import { useLocation, useNavigate } from "react-router-dom"; import { Locales, getHTMLTextDir, getLocaleName, getLocalizedUrl, } from "intlayer"; import { useLocale } from "react-intlayer"; import { type FC } from "react"; const LocaleSwitcher: FC = () => { const { pathname, search } = useLocation(); // Obtenez le chemin URL actuel. Exemple : /fr/about?foo=bar const navigate = useNavigate(); const { locale, availableLocales, setLocale } = useLocale({ onLocaleChange: (locale) => { // Construisez l'URL avec la locale mise à jour // Exemple : /es/about?foo=bar const pathWithLocale = getLocalizedUrl(`${pathname}${search}`, locale); // Mettez à jour le chemin URL navigate(pathWithLocale); }, }); return (
); }; ``` > Références de documentation : > > - [Hook `useLocale`](https://github.com/aymericzip/intlayer/blob/main/docs/docs/fr/packages/react-intlayer/useLocale.md) > - [Hook `getLocaleName`](https://github.com/aymericzip/intlayer/blob/main/docs/docs/fr/packages/intlayer/getLocaleName.md) > - [Hook `getLocalizedUrl`](https://github.com/aymericzip/intlayer/blob/main/docs/docs/fr/packages/intlayer/getLocalizedUrl.md) > - [Hook `getHTMLTextDir`](https://github.com/aymericzip/intlayer/blob/main/docs/docs/fr/packages/intlayer/getHTMLTextDir.md) > - [Attribut `hrefLang`](https://developers.google.com/search/docs/specialty/international/localized-versions?hl=fr) > - [Attribut `lang`](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/lang) > - [Attribut `dir`](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/dir) > - [Attribut `aria-current`](https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-current)
Lorsque votre application prend en charge plusieurs langues, il est crucial de mettre à jour les attributs `lang` et `dir` de la balise `` pour correspondre à la locale actuelle. Cela garantit : - **Accessibilité** : Les lecteurs d'écran et les technologies d'assistance s'appuient sur l'attribut `lang` correct pour prononcer et interpréter le contenu avec précision. - **Rendu du texte** : L'attribut `dir` (direction) garantit que le texte est rendu dans le bon ordre (par exemple, de gauche à droite pour l'anglais, de droite à gauche pour l'arabe ou l'hébreu), ce qui est essentiel pour la lisibilité. - **SEO** : Les moteurs de recherche utilisent l'attribut `lang` pour déterminer la langue de votre page, aidant à fournir le contenu localisé approprié dans les résultats de recherche. En mettant à jour ces attributs dynamiquement lorsque la locale change, vous garantissez une expérience cohérente et accessible pour les utilisateurs dans toutes les langues prises en charge. #### Implémentation du Hook Créez un hook personnalisé pour gérer les attributs HTML. Le hook écoute les changements de locale et met à jour les attributs en conséquence : ```tsx fileName="src/hooks/useI18nHTMLAttributes.tsx" codeFormat={["typescript", "esm"]} import { useEffect } from "react"; import { useLocale } from "react-intlayer"; import { getHTMLTextDir } from "intlayer"; /** * Met à jour les attributs `lang` et `dir` de l'élément HTML en fonction de la locale actuelle. * - `lang` : Informe les navigateurs et les moteurs de recherche de la langue de la page. * - `dir` : Garantit l'ordre de lecture correct (par exemple, 'ltr' pour l'anglais, 'rtl' pour l'arabe). * * Cette mise à jour dynamique est essentielle pour un rendu de texte correct, l'accessibilité et le SEO. */ export const useI18nHTMLAttributes = () => { const { locale } = useLocale(); useEffect(() => { // Mettez à jour l'attribut de langue à la locale actuelle. document.documentElement.lang = locale; // Définissez la direction du texte en fonction de la locale actuelle. document.documentElement.dir = getHTMLTextDir(locale); }, [locale]); }; ``` #### Utilisation du Hook dans votre application Intégrez le hook dans votre composant principal afin que les attributs HTML soient mis à jour chaque fois que la locale change : ```tsx fileName="src/App.tsx" codeFormat={["typescript", "esm"]} import type { FC } from "react"; import { IntlayerProvider, useIntlayer } from "react-intlayer"; import { useI18nHTMLAttributes } from "./hooks/useI18nHTMLAttributes"; import "./App.css"; const AppContent: FC = () => { // Appliquez le hook pour mettre à jour les attributs lang et dir de la balise en fonction de la locale. useI18nHTMLAttributes(); // ... Reste de votre composant }; const App: FC = () => ( ); export default App; ``` En appliquant ces modifications, votre application : - Garantira que l'attribut **langue** (`lang`) reflète correctement la locale actuelle, ce qui est important pour le SEO et le comportement du navigateur. - Ajustera la **direction du texte** (`dir`) en fonction de la locale, améliorant la lisibilité et l'utilisabilité pour les langues avec des ordres de lecture différents. - Fournira une expérience plus **accessible**, car les technologies d'assistance dépendent de ces attributs pour fonctionner de manière optimale.
### Configurer TypeScript Intlayer utilise l'augmentation de module pour bénéficier de TypeScript et renforcer votre base de code. ![Autocompletion](https://github.com/aymericzip/intlayer/blob/main/docs/assets/autocompletion.png?raw=true) ![Translation error](https://github.com/aymericzip/intlayer/blob/main/docs/assets/translation_error.png?raw=true) Assurez-vous que votre configuration TypeScript inclut les types générés automatiquement. ```json5 fileName="tsconfig.json" { // ... Vos configurations TypeScript existantes "include": [ // ... Vos configurations TypeScript existantes ".intlayer/**/*.ts", // Inclure les types générés automatiquement ], } ``` ### Configuration Git Il est recommandé d'ignorer les fichiers générés par Intlayer. Cela vous permet d'éviter de les ajouter à votre dépôt Git. Pour ce faire, vous pouvez ajouter les instructions suivantes à votre fichier `.gitignore` : ```plaintext fileName=".gitignore" # Ignorer les fichiers générés par Intlayer .intlayer ``` ### Extension VS Code Pour améliorer votre expérience de développement avec Intlayer, vous pouvez installer l’**extension officielle Intlayer pour VS Code**. [Installer depuis le Marketplace VS Code](https://marketplace.visualstudio.com/items?itemName=intlayer.intlayer-vs-code-extension) Cette extension offre : - **Autocomplétion** pour les clés de traduction. - **Détection d'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, consultez la [documentation de l'extension VS Code Intlayer](https://intlayer.org/doc/vs-code-extension). ### Aller plus loin Pour aller plus loin, vous pouvez implémenter l'[éditeur visuel](https://github.com/aymericzip/intlayer/blob/main/docs/docs/fr/intlayer_visual_editor.md) ou externaliser votre contenu en utilisant le [CMS](https://github.com/aymericzip/intlayer/blob/main/docs/docs/fr/intlayer_CMS.md). [Installation depuis le Marketplace VS Code](https://marketplace.visualstudio.com/items?itemName=intlayer.intlayer-vs-code-extension) Cette extension offre : - **L'autocomplétion** pour les clés de traduction. - **La détection d'erreurs en temps réel** pour les traductions manquantes. - **Des aperçus en ligne** du contenu traduit. - **Des actions rapides** pour créer et mettre à jour facilement les traductions. Pour plus de détails sur l'utilisation de l'extension, consultez la [documentation de l'extension Intlayer pour VS Code](https://intlayer.org/doc/vs-code-extension). ### Aller plus loin Pour aller plus loin, vous pouvez implémenter l'[éditeur visuel](https://github.com/aymericzip/intlayer/blob/main/docs/docs/fr/intlayer_visual_editor.md) ou externaliser votre contenu en utilisant le [CMS](https://github.com/aymericzip/intlayer/blob/main/docs/docs/fr/intlayer_CMS.md).