Спросите свой вопрос и получите сводку документа, используя эту страницу и выбранного вами поставщика AI
История версий
- "Обновление использования API useIntlayer в Solid для прямого доступа к свойствам"v8.9.004.05.2026
- "Добавлена команда init"v7.5.930.12.2025
- "Инициализация истории"v5.5.1029.06.2025
Содержимое этой страницы было переведено с помощью ИИ.
Смотреть последнюю версию оригинального контента на английскомЕсли у вас есть идея по улучшению этой документации, не стесняйтесь внести свой вклад, подав запрос на вытягивание на GitHub.
Ссылка на документацию GitHubКопировать Markdown документа в буфер обмена
Переведите ваш бэкенд на Hono с помощью Intlayer | Интернационализация (i18n)
hono-intlayer, это мощное промежуточное ПО (middleware) для интернационализации (i18n) приложений Hono, разработанное для того, чтобы сделать ваши бэкенд-сервисы доступными во всем мире, предоставляя локализованные ответы на основе предпочтений клиента.
Практические сценарии использования
Отображение ошибок бэкенда на языке пользователя: когда происходит ошибка, отображение сообщений на родном языке пользователя улучшает понимание и снижает раздражение. Это особенно полезно для динамических сообщений об ошибках, которые могут отображаться во фронтенд-компонентах, таких как уведомления (toasts) или модальные окна.
Получение многоязычного контента: для приложений, извлекающих контент из базы данных, интернационализация гарантирует, что вы сможете предоставлять этот контент на нескольких языках. Это критически важно для таких платформ, как сайты электронной коммерции или системы управления контентом, где необходимо отображать описания товаров, статьи и другой контент на языке, предпочтительном для пользователя.
Отправка многоязычных писем: будь то транзакционные письма, маркетинговые кампании или уведомления, отправка электронных писем на языке получателя может значительно повысить вовлеченность и эффективность.
Многоязычные push-уведомления: для мобильных приложений отправка push-уведомлений на предпочтительном языке пользователя может улучшить взаимодействие и удержание. Этот персональный подход делает уведомления более актуальными и побуждающими к действию.
Другие коммуникации: любая форма коммуникации со стороны бэкенда, такая как SMS-сообщения, системные оповещения или обновления пользовательского интерфейса, выигрывает от использования языка пользователя, обеспечивая ясность и улучшая общий пользовательский опыт.
Интернационализируя бэкенд, ваше приложение не только уважает культурные различия, но и лучше соответствует потребностям глобального рынка, что является ключевым шагом в масштабировании ваших услуг по всему миру.
Начало работы
See Application Template on GitHub.
Установка
Чтобы начать использовать hono-intlayer, установите пакет с помощью npm:
Копировать код в буфер обмена
npm install intlayer hono-intlayernpx intlayer initНастройка
Настройте параметры интернационализации, создав файл intlayer.config.ts в корне вашего проекта:
Копировать код в буфер обмена
import { Locales, type IntlayerConfig } from "intlayer";const config: IntlayerConfig = { internationalization: { locales: [ Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH_MEXICO, Locales.SPANISH_SPAIN, Locales.RUSSIAN, ], defaultLocale: Locales.ENGLISH, },};export default config;Объявление контента
Создавайте и управляйте объявлениями контента для хранения переводов:
Ваши объявления контента могут быть определены в любом месте вашего приложения, если они включены в каталогcontentDir(по умолчанию./src) и соответствуют расширению файла объявления контента (по умолчанию.content.{json,ts,tsx,js,jsx,mjs,cjs}).
Для получения более подробной информации обратитесь к документации по объявлению контента.
Настройка приложения Hono
Настройте ваше приложение Hono для использования hono-intlayer:
Копировать код в буфер обмена
import { Hono } from "hono";import { intlayer, t, getDictionary, getIntlayer } from "hono-intlayer";import dictionaryExample from "./index.content";const app = new Hono();// Загрузка обработчика запросов интернационализацииapp.use("*", intlayer());// Маршрутыapp.get("/t_example", (c) => { return c.text( t({ en: "Example of returned content in English", fr: "Exemple de contenu renvoyé en français", ru: "Пример возвращаемого контента на русском языке", }) );});app.get("/getIntlayer_example", (c) => { return c.json(getIntlayer("index").exampleOfContent);});app.get("/getDictionary_example", (c) => { return c.json(getDictionary(dictionaryExample).exampleOfContent);});export default app;Совместимость
hono-intlayer полностью совместим с:
react-intlayerдля React-приложенийnext-intlayerдля Next.js-приложенийvite-intlayerдля Vite-приложений
Он также бесшовно работает с любым решением для интернационализации в различных средах, включая браузеры и API-запросы. Вы можете настроить промежуточное ПО для определения локали через заголовки или файлы cookie:
Копировать код в буфер обмена
import { Locales, type IntlayerConfig } from "intlayer";const config: IntlayerConfig = { // ... Другие параметры конфигурации middleware: { headerName: "my-locale-header", cookieName: "my-locale-cookie", },};export default config;По умолчанию hono-intlayer будет интерпретировать заголовок Accept-Language для определения предпочтительного языка клиента.
Для получения дополнительной информации о конфигурации и расширенных темах посетите нашу документацию.
Настройка TypeScript
hono-intlayer использует возможности TypeScript для улучшения процесса интернационализации. Статическая типизация TypeScript гарантирует, что каждый ключ перевода учтен, что снижает риск пропущенных переводов и улучшает поддерживаемость.
Убедитесь, что автоматически сгенерированные типы (по умолчанию в ./types/intlayer.d.ts) включены в ваш файл tsconfig.json.
Копировать код в буфер обмена
{ // ... Ваши существующие конфигурации TypeScript "include": [ // ... Ваши существующие конфигурации TypeScript ".intlayer/**/*.ts", // Включить автоматически сгенерированные типы ],}Расширение VS Code
Для улучшения процесса разработки с Intlayer вы можете установить официальное расширение Intlayer VS Code.
Установить из VS Code Marketplace
Это расширение предоставляет:
- Автодополнение для ключей перевода.
- Обнаружение ошибок в реальном времени для пропущенных переводов.
- Встроенный просмотр переведенного контента.
- Быстрые действия для легкого создания и обновления переводов.
Для получения более подробной информации о том, как использовать расширение, обратитесь к документации расширения Intlayer VS Code.
Настройка Git
Рекомендуется игнорировать файлы, генерируемые Intlayer. Это позволит избежать их фиксации в вашем Git-репозитории.
Для этого вы можете добавить следующие инструкции в ваш файл .gitignore:
Копировать код в буфер обмена
# Игнорировать файлы, генерируемые Intlayer.intlayer