Creation:2025-08-23Last update:2026-05-06

    Integracja z Next.js: Dokumentacja hooka useIntlayer

    Hook useIntlayer jest dostosowany do aplikacji Next.js, aby efektywnie pobierać i zarządzać zlokalizowaną zawartością. Ta dokumentacja skupia się na tym, jak korzystać z hooka w projektach Next.js, zapewniając prawidłowe praktyki lokalizacyjne.

    Importowanie useIntlayer w Next.js

    W zależności od tego, czy pracujesz nad komponentami po stronie klienta, czy po stronie serwera w aplikacji Next.js, możesz zaimportować hook useIntlayer w następujący sposób:

    • Komponent klienta:

      typescript
      import { useIntlayer } from "next-intlayer"; // Używane w komponentach po stronie klienta
    • Komponent serwera:

      tsx
      import { useIntlayer } from "next-intlayer/server"; // Używane w komponentach po stronie serwera

    Parametry

    1. key: Identyfikator klucza słownika w postaci łańcucha znaków, z którego chcesz pobrać zawartość.
    2. locale (opcjonalny): Konkretna lokalizacja do użycia. Jeśli zostanie pominięta, hook domyślnie użyje lokalizacji ustawionej w kontekście klienta lub serwera.

    Pliki słownika

    Kluczowe jest, aby wszystkie klucze zawartości były zdefiniowane w plikach deklaracji zawartości, aby zapobiec błędom w czasie wykonywania i zapewnić bezpieczeństwo typów. Takie podejście ułatwia również integrację z TypeScript dla walidacji na etapie kompilacji.

    Instrukcje dotyczące konfigurowania plików deklaracji zawartości są dostępne tutaj.

    Przykład użycia w Next.js

    Oto jak można zaimplementować hook useIntlayer na stronie Next.js, aby dynamicznie ładować zlokalizowaną zawartość w oparciu o aktualną lokalizację aplikacji:

    src/pages/[locale]/index.tsx
    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>
        </>
      );
    };
    src/components/ClientComponentExample.tsx
    "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>  );};
    "use-client";
    import { useIntlayer } from "next-intlayer";const ServerComponentExample = () => {  const content = useIntlayer("component-content");  return (    <div>      <h1>{content.title}</h1>      <p>{content.description}</p>    </div>  );};
    src/components/ServerComponentExample.tsx
    tsx fileName="src/components/ServerComponentExample.tsx" codeFormat="typescript"
    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>
      );
    };

    Obsługa lokalizacji atrybutów

    Aby lokalizować atrybuty takie jak alt, title, href, aria-label itp., upewnij się, że poprawnie odwołujesz się do zawartości:

    tsx
    <img src={content.image.src.value} alt={content.image.alt.value} /><img src={content.image.src.toString()} alt={content.image.alt.toString()} /><img src={String(content.image.src)} alt={String(content.image.alt)} />

    Dalsze informacje

    • Intlayer Visual Editor: Dowiedz się, jak korzystać z edytora wizualnego, aby łatwiej zarządzać treścią tutaj.

    Niniejsza dokumentacja opisuje użycie hooka useIntlayer specjalnie w środowiskach Next.js, oferując solidne rozwiązanie do zarządzania lokalizacją w Twoich aplikacjach Next.js.