React Интеграция: Документация на Хук useIntlayer

    Этот раздел предоставляет подробные рекомендации по использованию хука useIntlayer в React приложениях, позволяя эффективно локализовать контент.

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

    Хук useIntlayer можно интегрировать в React приложения, импортируя его в зависимости от контекста:

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

      typescript
      import { useIntlayer } from "react-intlayer"; // Используется в клиентских React компонентах
    • Серверный Компонент:

    Параметры

    Хук принимает два параметра:

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

    Объявление Контента

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

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

    Демонстрация хука useIntlayer внутри React компонента:

    src/app.tsx
    import type { FC } from "react";import { ClientComponentExample, ServerComponentExample } from "@components";import { IntlayerProvider } from "react-intlayer";import { useIntlayer, IntlayerServerProvider } from "react-intlayer/server";import { Locales } from "intlayer";const App: FC<{ locale: Locales }> = ({ locale }) => {  const content = useIntlayer("homepage", locale);  return (    <>      <p>{content.introduction}</p>      <IntlayerProvider locale={locale}>        <ClientComponentExample />      </IntlayerProvider>      <IntlayerServerProvider locale={locale}>        <ServerComponentExample />      </IntlayerServerProvider>    </>  );};
    src/components/ComponentExample.tsx
    import type { FC } from "react";import { useIntlayer } from "react-intlayer";const ComponentExample: FC = () => {  const content = useIntlayer("component-example");  return (    <div>      <h1>{content.title}</h1>      <p>{content.description}</p>    </div>  );};
    src/components/ServerComponentExample.tsx
    import { useIntlayer } from "react-intlayer/server";const ServerComponentExample = () => {  const content = useIntlayer("server-component");  return (    <div>      <h1>{content.title}</h1>      <p>{content.description}</p>    </div>  );};

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

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

    jsx
    <button title={content.buttonTitle.value}>{content.buttonText}</button>

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

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

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

    Если у вас есть идея по улучшению этой документации, не стесняйтесь внести свой вклад, подав запрос на вытягивание на GitHub.

    Ссылка на документацию GitHub