Skip to Content

Next.js I18n

Note

This feature is only available in the docs theme.

Nextra supports Next.js Internationalized Routing out of the box.

To add multi-language pages to your Nextra application, just need to config i18n in next.config.mjs:

next.config.mjs
import nextra from 'nextra' const withNextra = nextra({ theme: 'nextra-theme-docs', themeConfig: './theme.config.js' }) export default withNextra({ i18n: { locales: ['en', 'zh', 'de'], defaultLocale: 'en' } })

Then, add the locale codes to your file extensions (required for the default locale too):

/pages index.en.md index.zh.md index.de.md meta.en.json meta.zh.json meta.de.json ...

Finally, add the i18n option to your theme.config.js to configure the language dropdown:

theme.config.js
i18n: [ { locale: 'en', text: 'English' }, { locale: 'zh', text: '中文' }, { locale: 'de', text: 'Deutsch' }, { locale: 'ar', text: 'العربية', direction: 'rtl' } ]
Last updated on