Creation:2024-08-11Last update:2026-01-26

    Integrazione Next.js: Documentazione dell'hook useLocale per next-intlayer

    Questa sezione offre una documentazione dettagliata sull'hook useLocale pensato per applicazioni Next.js all'interno della libreria next-intlayer. È progettato per gestire in modo efficiente i cambiamenti di locale e il routing.

    Importare useLocale in Next.js

    Per utilizzare l'hook useLocale nella tua applicazione Next.js, importalo come mostrato di seguito:

    javascript
    import { useLocale } from "next-intlayer"; // Usato per gestire i locali e il routing in Next.js

    Utilizzo

    Ecco come implementare l'hook useLocale all'interno di un componente Next.js:

    src/components/LocaleSwitcher.tsx
    "use client";
    
    import type { FC } from "react";
    import { Locales } from "intlayer";
    import { useLocale } from "next-intlayer";
    
    const LocaleSwitcher: FC = () => {
      const { locale, defaultLocale, availableLocales, setLocale } = useLocale();
    
      return (
        <div>
          <h1>Locale Corrente: {locale}</h1>
          <p>Locale Predefinito: {defaultLocale}</p>
          <select value={locale} onChange={(e) => setLocale(e.target.value)}>
            {availableLocales.map((loc) => (
              <option key={loc} value={loc}>
                {loc}
              </option>
            ))}
          </select>
        </div>
      );
    };

    Parametri

    L'hook useLocale accetta i seguenti parametri:

    • onLocaleChange: Una stringa che determina come l'URL deve essere aggiornato quando cambia la locale. Può essere "replace", "push" o "none".

      Facciamo un esempio:

      1. Sei su /fr/home
      2. Navighi su /fr/about
      3. Cambi la locale in /es/about
      4. Clicchi sul pulsante "indietro" del browser

      Il comportamento differirà in base al valore di onLocaleChange:

      • "replace" (predefinito): Sostituisce l'URL corrente con il nuovo URL localizzato e imposta il cookie. -> Il pulsante "indietro" andrà su /es/home
      • "push": Aggiunge il nuovo URL localizzato alla cronologia del browser e imposta il cookie. -> Il pulsante "indietro" andrà su /fr/about
      • "none": Aggiorna solo la locale nel contesto del client e imposta il cookie, senza cambiare l'URL. -> Il pulsante "indietro" andrà su /fr/home
      • (locale) => void: Imposta il cookie e attiva una funzione personalizzata che verrà chiamata quando cambia la locale.

        L'opzione undefined è il comportamento predefinito poiché consigliamo di utilizzare il componente Link per navigare verso la nuova locale. Esempio:

        tsx
        <Link href="/es/about" replace>  Chi siamo</Link>

    Valori di Ritorno

    • locale: La locale corrente come impostata nel contesto React.
    • defaultLocale: La locale primaria definita nella configurazione.
    • availableLocales: Una lista di tutte le localizzazioni disponibili come definite nella configurazione.
    • setLocale: Una funzione per cambiare la locale dell'applicazione e aggiornare di conseguenza l'URL. Gestisce le regole del prefisso, decidendo se aggiungere o meno la locale al percorso in base alla configurazione. Utilizza useRouter da next/navigation per le funzioni di navigazione come push e refresh.
    • pathWithoutLocale: Una proprietà calcolata che restituisce il percorso senza la locale. È utile per confrontare gli URL. Ad esempio, se la locale corrente è fr e l'URL è fr/my_path, il percorso senza locale è /my_path. Utilizza usePathname da next/navigation per ottenere il percorso corrente.

    Conclusione

    L'hook useLocale di next-intlayer è uno strumento fondamentale per la gestione delle localizzazioni nelle applicazioni Next.js. Offre un approccio integrato per adattare la tua applicazione a più localizzazioni gestendo senza soluzione di continuità l'archiviazione della locale, la gestione dello stato e le modifiche degli URL.