Le applicazioni Windows Phone riprendono il modello di navigazione tra le pagine introdotto da Silverlight: l'utente può visualizzare il contenuto delle pagine e navigante tra esse, come se fosse in un browser.
La corrispondenza tra l'Uri e il file fisico, ovvero la pagina XAML, avviene mediante un componente particolare, chiamato UriMapper.
Ci sono casi, però, in cui realizzarne un UriMapper custom è indispensabile: ad esempio, quando dobbiamo fornire la nostra logica di rooting ed indirizzare l'utente a pagine differenti, in base ad un parametro presente nell'Uri.
Creare un UriMapper è semplicissimo: ci basta estendere la classe UriMapperBase.
class MyUriMapper : UriMapperBase { private string tempUri; public override Uri MapUri(Uri uri) { tempUri = uri.ToString(); // controllo il contenuto dell?uri if (tempUri.Contains("ViewfinderLaunch")) { // restituisco l?uri appropriato return new Uri("/myView.xaml", UriKind.Relative); } // altrimenti non faccio nessun cambiamento return uri; } }
Creata la classe, dobbiamo eseguire l'ovveride del motodo MapUri. Il codice all'intero del metodo è semplice: recuperato l'Uri, controlliamo il contenuto, se utile all'applicazione, e modifichiamo l'Uri effettivamente restituito.
Creata la classe, non ci resta che modificare il file App.xaml.cs. Dobbiamo identificare la parte di inizializzazione e aggiungere la seguente riga:
RootFrame.UriMapper = new MyUriMapper();
Personalizzare il rooting degli Uri ci permette di controllare in modo semplice ed efficace le pagine visualizzate dall'applicazione, oltre a gestire scenari in cui cambiamo nome ad una pagina e vogliamo continuare a mantenere i meccanismi di navigazione (ad esempio, perché gli Uri arrivano da notifiche di tipo push).
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Evitare la command injection in un workflow di GitHub
Utilizzare l'operatore GroupBy come ultima istruzione di una query LINQ in Entity Framework
Eseguire attività pianificate con Azure Container Jobs
Come EF 8 ha ottimizzato le query che usano il metodo Contains
Eseguire operazioni con timeout in React
Utilizzare Model as a Service su Microsoft Azure
Utilizzare le Cache API di JavaScript per salvare elementi nella cache del browser
Filtrare e rimuovere gli elementi dalla cache del browser tramite le API JavaScript
Utilizzare Tailwind CSS all'interno di React: installazione
Creare form tipizzati con Angular
Gestire i null nelle reactive form tipizzate di Angular
Eseguire query manipolando le liste contenute in un oggetto mappato verso una colonna JSON