Задайте вопрос и получите краткое содержание документа через любого ИИ-провайдера на этой странице
История версий
- Добавлен плагин loadJSONv7.0.601.11.2025
- Переход на плагин syncJSON и полный переписанный кодv7.0.029.10.2025
Содержимое этой страницы было переведено с помощью ИИ.
Смотреть последнюю версию оригинального контента на английскомIf 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
Интернационализация Next.js (i18n) с next-i18next и Intlayer
Содержание
Что такое Intlayer?
Intlayer, это инновационная, открытая библиотека интернационализации, разработанная для устранения недостатков традиционных решений i18n. Она предлагает современный подход к управлению контентом в приложениях Next.js.
Смотрите конкретное сравнение с next-intl в нашем блоге next-i18next vs. next-intl vs. Intlayer.
Почему стоит сочетать Intlayer с next-i18next?
Хотя Intlayer предоставляет отличное автономное решение для i18n (см. наше руководство по интеграции с Next.js), вы можете захотеть комбинировать его с next-i18next по нескольким причинам:
- Существующая кодовая база: У вас уже есть реализованная система next-i18next, и вы хотите постепенно перейти на улучшенный опыт разработки с Intlayer.
- Требования наследия: Ваш проект требует совместимости с существующими плагинами или рабочими процессами i18next.
- Знакомство команды: Ваша команда привыкла к next-i18next, но хочет лучшее управление контентом.
Для этого Intlayer может быть реализован как адаптер для next-i18next, чтобы помочь автоматизировать ваши JSON-переводы в CLI или CI/CD пайплайнах, тестировать ваши переводы и многое другое.
В этом руководстве показано, как использовать превосходную систему декларации контента Intlayer, сохраняя при этом совместимость с next-i18next.
Пошаговое руководство по настройке Intlayer с next-i18next
Установка зависимостей
Установите необходимые пакеты с помощью предпочитаемого менеджера пакетов:
bashКопировать кодКопировать код в буфер обмена
npx intlayer-cli init --interactiveфлаг
--interactiveне является обязательным. Используйтеintlayer-cli init, если вы являетесь ИИ-агентом.Эта команда определит вашу среду и установит необходимые пакеты. Например:
bashКопировать кодКопировать код в буфер обмена
npm install intlayer @intlayer/sync-json-plugin --save-devОбъяснение пакетов:
- intlayer: Основная библиотека для декларации и управления контентом
- @intlayer/sync-json-plugin: Плагин для синхронизации деклараций контента Intlayer с форматом JSON i18next
Реализация плагина Intlayer для обёртывания JSON
Создайте файл конфигурации Intlayer для определения поддерживаемых локалей:
Если вы также хотите экспортировать JSON-словарь для i18next, добавьте плагин
syncJSON:intlayer.config.tsКопировать кодКопировать код в буфер обмена
import { Locales, type IntlayerConfig } from "intlayer";import { syncJSON } from "@intlayer/sync-json-plugin";const config: IntlayerConfig = { internationalization: { locales: [Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH], defaultLocale: Locales.ENGLISH, }, plugins: [ syncJSON({ source: ({ key, locale }) => `./public/locales/${locale}/${key}.json`, }), ],};export default config;Плагин
syncJSONавтоматически обернет JSON. Он будет читать и записывать JSON-файлы без изменения архитектуры контента.Если вы хотите, чтобы JSON сосуществовал с файлами декларации контента Intlayer (
.contentфайлы), Intlayer будет работать следующим образом:plaintextКопировать кодКопировать код в буфер обмена
1. загрузит как JSON, так и файлы декларации контента и преобразует их в словарь Intlayer.2. если возникнут конфликты между JSON и файлами декларации контента, Intlayer выполнит слияние всех словарей. В зависимости от приоритета плагинов и файлов декларации контента (все настраивается).Если изменения внесены с помощью CLI для перевода JSON или с использованием CMS, Intlayer обновит JSON-файл с новыми переводами.
Для получения дополнительной информации о плагине
syncJSONобратитесь к документации плагина syncJSON.
Конфигурация Git
Исключите сгенерированные файлы из системы контроля версий:
Копировать код в буфер обмена
# Игнорировать файлы, сгенерированные Intlayer.intlayerЭти файлы автоматически пересоздаются во время процесса сборки и не требуют коммита в ваш репозиторий.
Расширение VS Code
Для улучшения опыта разработчика установите официальное расширение Intlayer для VS Code:
Комментарии
Пока нет комментариев. Будьте первым, кто поделится своими мыслями.