Notizie sui prodotti

Jetpack Navigation 3 è stabile

Lettura di 3 minuti
Don Turner
Ingegnere per le relazioni con gli sviluppatori

Jetpack Navigation 3 versione 1.0 è stabile 🎉. Inizia subito a utilizzarla nelle tue app di produzione. JetBrains la sta già utilizzando nella sua app KotlinConf.

Navigation 3 è una nuova libreria di navigazione creata da zero per adottare lo stato di Jetpack Compose. Ti offre il controllo completo del back stack, ti aiuta a conservare lo stato di navigazione e ti consente di creare facilmente layout adattivi (come l'elenco-dettagli). Esiste anche una versione multipiattaforma di JetBrains.

Perché una nuova libreria?

La libreria Jetpack Navigation originale (ora Nav2) è stata progettata 7 anni fa e, sebbene soddisfi bene i suoi obiettivi originali e sia stata migliorata in modo iterativo, il modo in cui le app vengono create ora è cambiato radicalmente. 

La programmazione reattiva con un'interfaccia utente dichiarativa è ora la norma. Nav3 adotta questo approccio. Ad esempio, NavDisplay (il componente dell'interfaccia utente di Nav3 che mostra le schermate) osserva semplicemente un elenco di chiavi (ognuna che rappresenta una schermata) supportato dallo stato di Compose e aggiorna la sua interfaccia utente quando l'elenco cambia.

nav-display.png

Nav2 può anche rendere difficile avere un'unica fonte di verità per lo stato di navigazione perché ha il proprio stato interno. Con Nav3, fornisci il tuo stato, il che ti dà il controllo completo.

Infine, ci hai chiesto maggiore flessibilità e personalizzazione. Anziché avere una singola API monolitica, Nav3 fornisce API più piccole e disaccoppiate (o "blocchi predefiniti") che possono essere combinate per creare funzionalità complesse. Nav3 stesso utilizza questi blocchi predefiniti per fornire valori predefiniti sensati per casi d'uso di navigazione ben definiti. 

Questo approccio ti consente di: 

Scopri di più sul design e sulle funzionalità nel blog di lancio

Eseguire la migrazione da Navigation 2

Se utilizzi già Nav2, in particolare Navigation Compose, ti consigliamo di eseguire la migrazione a Nav3. Per aiutarti, è disponibile una guida alla migrazione. I passaggi principali sono: 

  1. Aggiungi le dipendenze di Navigation 3.
  2. Aggiorna le route di navigazione per implementare NavKey. Le route non devono implementare questa interfaccia per utilizzare Nav3, ma se lo fanno, puoi sfruttare la funzione rememberNavBackStack di Nav3 per creare un back stack persistente.
  3. Crea classi per contenere e modificare lo stato di navigazione. Qui vengono memorizzati gli stack indietro.
  4. Sostituisci NavController con queste classi.
  5. Sposta le destinazioni da NavGraph di NavHost a un entryProvider.
  6. Sostituisci NavHost con NavDisplay.

Sperimentare la migrazione degli agenti AI

Potresti voler provare a utilizzare un agente AI per leggere la guida alla migrazione ed eseguire i passaggi sul tuo progetto. Per provare questa funzionalità con Gemini in modalità Agent di Android Studio:

  • Salva questa versione Markdown della guida nel tuo progetto.
  • Incolla questo prompt nell'agente (ma non premere Invio): "Migra questo progetto a Navigation 3 utilizzando ".
  • Digita @migration-guide.md. In questo modo, la guida verrà fornita come contesto all'agente.

Come sempre, assicurati di esaminare attentamente le modifiche apportate dall'agente AI, perché può commettere errori.

Ci piacerebbe sapere come hai eseguito la migrazione o come l'ha eseguita il tuo agente. Invia il tuo feedback qui.

Ricette di navigazione utili per scenari comuni

Per i casi d'uso comuni ma sfumati, abbiamo un repository di ricette. Questo mostra come combinare le API Nav3 in un modo particolare, consentendoti di scegliere o modificare la ricetta in base alle tue esigenze specifiche. Se una ricetta si rivela popolare, valuteremo di "promuovere" le parti non sfumate nella libreria Nav3 principale o nelle librerie aggiuntive. 

code-recipes.png

Al momento sono disponibili 19 ricette, tra cui: 

Stiamo lavorando a una ricetta per i link diretti e a un'integrazione di Koin e ne abbiamo in programma molte altre. Un ingegnere di JetBrains ha anche pubblicato una versione di Compose Multiplatform delle ricette.

Se hai un caso d'uso comune per cui ti piacerebbe vedere una ricetta, ti preghiamo di inviare una richiesta di ricetta

Riepilogo

Per iniziare a utilizzare Nav3, consulta la documentazione e le ricette. Inoltre, non perderti una settimana intera di contenuti tecnici, tra cui: 

  • Un video approfondito sull'API che tratta di modularizzazione, animazioni e layout adattivi.
  • Una sessione di domande e risposte in diretta con gli ingegneri che hanno creato Nav3.

La settimana di approfondimento su Nav3 inizia il 1° dicembre 2025. 


Come sempre, se riscontri problemi, segnalali qui

Scritto da:

Continua a leggere