Quando un'app basata su AngularJS diventa complessa, entra in gioco la necessità di componentizzare i template e i rispettivi controller.
Generalmente questo obiettivo si ottiene dividendo le funzionalità all'interno di file, che poi gestiremo attraverso $routeProvider, che è fornito dal servizio $route. Il compito del servizio di routing è quello di unire controller, view e l'URL mostrato nel browser, consentendo anche di sfruttare la navigazione del browser, sia andando avanti ed indietro, sia puntando direttamente ad un URL.
Perché il servizio posso funzionare, dobbiamo include un riferimento a angular-route.js nella pagina principale (diciamo la classica index.html) e poi referenziare localmente nell'app.js il nostro servizio:
var myApp = angular.module('myApp', [ 'ngRoute', 'myAppControllers' ]);
E poi configurare le route:
myApp.config(['$routeProvider', function($routeProvider) { $routeProvider. when('/list', { templateUrl: 'views/orders/list.html', controller: 'OrderListController' }). when('/details/:Id', { templateUrl: 'views/orders/detail.html', controller: 'OrderDetailController' }). otherwise({ redirectTo: '/' }); }]);
Quello che otterremo con questa configurazione è che:
- navigando verso list, allora sarà utilizzare il controller OrderListController e la view list.html, nel percorso specificato;
- navigando verso details/{id}, allora sarà utilizzare il controller OrderDetailController, a cui sarà passato il nostro ID e la view detail.html, nel percorso specificato;
- in caso contrario, il browser tornerà alla home attraverso un redirect
A tal proposito, per recuperare il parametro di navigazione, ci basterà utilizzare un codice come quello che segue, posto all'interno del codice caricato in fase di partenza del controller e recuperato con $routeParams:
var myAppControllers = angular.module('myAppControllers', []); myAppControllers.controller('OrderDetailController', ['$scope', '$routeParams', function($scope, $routeParams) { $scope.id = $routeParams.id; }]);
Vedremo come, grazie a questa modifica, potremo utilizzare normalmente l'history del browser per navigare, consentendo all'utente di utilizzare in maniera più semplice la nostra applicazione web.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Modificare i metadati nell'head dell'HTML di una Blazor Web App
Usare le navigation property in QuickGrid di Blazor
Migliorare la scalabilità delle Azure Function con il Flex Consumption
Generare la software bill of material (SBOM) in GitHub
Filtrare i dati di una QuickGrid in Blazor con una drop down list
Creare una custom property in GitHub
Usare il colore CSS per migliorare lo stile della pagina
Gestire la cancellazione di una richiesta in streaming da Blazor
Creare alias per tipi generici e tuple in C#
Gestire il colore CSS con HWB
Sfruttare MQTT in cloud e in edge con Azure Event Grid
Gestire i dati con Azure Cosmos DB Data Explorer
I più letti di oggi
- Popolare una classe a partire dal testo, con Semantic Kernel e ASP.NET Core Web API
- Il nuovo tag nav in HTML5
- Nullish coalescing e decostruzione in JavaScript
- Silverlight Summer: un'estate speciale piena di Style per i controlli Silverlight!
- Microsoft Security Bulletin MS02-036
- Un documento con le novità del .NET framework 1.1