Создание:2024-08-11Последнее обновление:2025-06-29

    Интеграция с React: Документация по хуку useI18n

    В этом разделе представлено подробное руководство по использованию хука useI18n в приложениях React, что позволяет эффективно локализовать контент.

    Импортирование useI18n в React

    Хук useI18n можно импортировать и интегрировать в приложения React в зависимости от контекста следующим образом:

    • Клиентские компоненты:

      import { useI18n } from "react-intlayer"; // Используйте в клиентских React-компонентах
      import { useI18n } from "react-intlayer"; // Используйте в клиентских React-компонентах
      const { useI18n } = require("react-intlayer"); // Используйте в клиентских React-компонентах
    • Серверные компоненты:

      import { useI18n } from "react-intlayer/server"; // Используйте в серверных React-компонентах
      import { useI18n } from "react-intlayer/server"; // Используйте в серверных React-компонентах
      const { useI18n } = require("react-intlayer/server"); // Используйте в серверных React-компонентах

    Параметры

    Этот хук принимает два параметра:

    1. namespace: Пространство имён словаря для ограничения области ключей перевода.
    2. locale (необязательно): Желаемая локаль. Если не указана, по умолчанию будет использоваться локаль из контекста.

    Словарь

    Все ключи словаря должны быть объявлены в файлах декларации контента для повышения безопасности типов и предотвращения ошибок. Инструкции по настройке можно найти здесь.

    Примеры использования в React

    Примеры использования хука useI18n в React-компонентах:

    import type { FC } from "react";
    import { ClientComponentExample, ServerComponentExample } from "@components";
    import { IntlayerProvider } from "react-intlayer";
    import { useI18n, IntlayerServerProvider } from "react-intlayer/server";
    import { Locales } from "intlayer";
    
    const App: FC<{ locale: Locales }> = ({ locale }) => {
      const t = useI18n("home-page", locale);
    
      return (
        <>
          <p>{t("introduction")}</p>
          <IntlayerProvider locale={locale}>
            <ClientComponentExample />
          </IntlayerProvider>
          <IntlayerServerProvider locale={locale}>
            <ServerComponentExample />
          </IntlayerServerProvider>
        </>
      );
    };
    import type { FC } from "react";
    import { useI18n } from "react-intlayer";
    
    const ComponentExample: FC = () => {
      const t = useI18n("component-example");
    
      return (
        <div>
          <h1>{t("title")}</h1> {/* Отобразить заголовок */}
          <p>{t("description")}</p> {/* Отобразить описание */}
        </div>
      );
    };
    import { useI18n } from "react-intlayer/server";
    
    const ServerComponentExample = () => {
      const t = useI18n("server-component");
    
      return (
        <div>
          <h1>{t("title")}</h1> {/* Отобразить заголовок */}
          <p>{t("description")}</p> {/* Отобразить описание */}
        </div>
      );
    };

    Обработка атрибутов

    При локализации атрибутов обращайтесь к значениям перевода соответствующим образом:

    <!-- Для атрибутов доступности (например, aria-label) используйте .value, так как требуются чистые строки -->
    <button aria-label={t("button.ariaLabel").value}>{t("button.text")}</button>

    Дополнительные ресурсы

    • Визуальный редактор Intlayer: Для более интуитивного управления контентом обратитесь к документации по визуальному редактору здесь.

    Этот раздел специально охватывает интеграцию хука useI18n в React-приложениях, упрощая процесс локализации и обеспечивая согласованность контента между различными локалями.