Интеграция с Next.js: Документация для Хука useIntlayer
Хук useIntlayer предназначен для приложений Next.js для эффективной выборки и управления локализованным контентом. Эта документация сосредоточена на том, как использовать хук в проектах Next.js, обеспечивая правильные практики локализации.
Импорт useIntlayer в Next.js
В зависимости от того, работаете ли вы с компонентами на стороне клиента или сервера в приложении Next.js, вы можете импортировать хук useIntlayer следующим образом:
Компонент клиента:
typescriptimport { useIntlayer } from "next-intlayer"; // Используется в компонентах на стороне клиента
Компонент сервера:
tsximport { useIntlayer } from "next-intlayer/server"; // Используется в компонентах на стороне сервера
Параметры
- key: Строковый идентификатор для ключа словаря, из которого вы хотите получить контент.
- locale (опционально): Определенная локаль для использования. Если не указано, хук по умолчанию использует локаль, установленную в контексте клиента или сервера.
Файлы Декларации Контента
Крайне важно, чтобы все ключи контента были определены в файлах декларации контента, чтобы предотвратить ошибки во время выполнения и обеспечить безопасность типов. Этот подход также облегчает интеграцию TypeScript для валидации на этапе компиляции.
Инструкции по настройке файлов декларации контента доступны здесь.
Пример Использования в Next.js
Вот как вы можете реализовать хук useIntlayer на странице Next.js для динамической загрузки локализованного контента в зависимости от текущей локали приложения:
import { ClientComponentExample } from "@components/ClientComponentExample";import { ServerComponentExample } from "@components/ServerComponentExample";import { type NextPageIntlayer, IntlayerClientProvider } from "next-intlayer";import { useIntlayer, IntlayerServerProvider } from "next-intlayer/server";const HomePage: NextPageIntlayer = async ({ params }) => { const { locale } = await params; const content = useIntlayer("homepage", locale); return ( <> <p>{content.introduction}</p> <IntlayerClientProvider locale={locale}> <ClientComponentExample /> </IntlayerClientProvider> <IntlayerServerProvider locale={locale}> <ServerComponentExample /> </IntlayerServerProvider> </> );};
"use-client";import type { FC } from "react";import { useIntlayer } from "next-intlayer";const ClientComponentExample: FC = () => { const content = useIntlayer("component-content"); return ( <div> <h1>{content.title}</h1> <p>{content.description}</p> </div> );};
import type { FC } from "react";import { useIntlayer } from "next-intlayer/server";const ServerComponentExample: FC = () => { const content = useIntlayer("component-content"); return ( <div> <h1>{content.title}</h1> <p>{content.description}</p> </div> );};
Обработка Локализации Атрибутов
Чтобы локализовать атрибуты, такие как alt, title, href, aria-label и т. д., убедитесь, что вы правильно ссылаетесь на контент:
<img src={content.image.src.value} alt={content.image.alt.value} />
Дополнительная Информация
- Интерактивный Редактор Intlayer: Узнайте, как использовать визуальный редактор для более удобного управления контентом здесь.
Эта документация описывает использование хука useIntlayer специально в среде Next.js, предоставляя надежное решение для управления локализацией в ваших приложениях Next.js.
Если у вас есть идея по улучшению этой документации, не стесняйтесь внести свой вклад, подав запрос на вытягивание на GitHub.
Ссылка на документацию GitHub