astro-i18next
can be loaded in both server and client side.
npm install astro-i18next @astrojs/react react-i18next
-
Add
astro-i18next
to yourastro.config.mjs
:import { defineConfig } from "astro/config"; import react from "@astrojs/react"; import astroI18next from "astro-i18next"; export default defineConfig({ integrations: [react(), astroI18next()], });
-
Configure
astro-i18next
in yourastro-i18next.config.mjs
file:/** @type {import('astro-i18next').AstroI18nextConfig} */ export default { defaultLocale: "en", locales: ["en", "fr"], load: ["server", "client"], // load i18next server and client side i18nextServerPlugins: { "{initReactI18next}": "react-i18next", }, i18nextClientPlugins: { "{initReactI18next}": "react-i18next", }, };
-
By default,
astro-i18next
expects your translations to be organized inside yourpublic
folder, in alocales
folder:public └── locales # create this folder to store your translation strings ├── en | └── translation.json └── fr └── translation.json
That's it! You can now start translating!
i18next-browser-languageDetector
plugin.
To have the page locale be detected, the default configuration is set to check
for the html lang
attribute in your page:
---
import i18next from "i18next";
---
<html lang={i18next.language}>...</html>
Feel free to check astro-i18next's documentation.