Nel corso del nostro articolo introduttivo su ASP.NET MVC 3, abbiamo visto come la gestione delle Layout View in Razor presenti qualche differenza rispetto a quanto eravamo abituati a fare con le Master Page del Web Forms View Engine.
In Razor, infatti, tramite il metodo RenderBody possiamo indicare il punto, nel layout della pagina, dove dovrà essere posizionato l'intero contenuto della View che sarà renderizzata.
<html> <head> ... </head> <body> @RenderBody() </body> </html>
Spesso, però, si ha la necessità di definire delle sezioni addizionali, in altri punti del layout, in cui le View potranno eventualmente aggiungere del contenuto personalizzato. In Razor, questi placeholder aggiuntivi vengono chiamati Section e possono essere definiti, all'interno delle singole View, tramite il tag @section.
@section footer { <div>Copyright © 2001 by Marco De Sanctis</div> }
Nel codice in alto, ad esempio, abbiamo realizzato una section denominata "footer", che potrà poi essere visualizzata all'interno della Layout View sfruttando il metodo RenderSection.
<body> @RenderBody() <div id="footer"> @RenderSection("footer", required:false) </div> </body>
Questo metodo, oltre al nome della sezione da visualizzare, ammette un secondo parametro required, tramite cui possiamo specificare se essa debba essere obbligatoriamente presente all'interno della view.
Nel caso di sezioni opzionali, può essere utile voler definire un layout di default, da utilizzare quando queste non siano specificate nella View visualizzata. Un simile risultato può essere ottenuto tramite il metodo IsSectionDefined, come nell'esempio seguente.
<body> @RenderBody() <div id="footer"> @if (!IsSectionDefined("footer")) { <div>Footer di default</div> } @RenderSection("footer", required:false) </div> </body>
Per approfondimenti
Introduzione ad ASP.NET MVC 3https://www.aspitalia.com/articoli/asp.net-mvc/mvc3-overview.aspx
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Eseguire query manipolando le liste contenute in un oggetto mappato verso una colonna JSON
Bloccare l'esecuzione di un pod in mancanza di un'artifact attestation di GitHub
Ordine e importanza per @layer in CSS
Ottimizzazione dei block template in Angular 17
Configurare lo startup di applicazioni server e client con .NET Aspire
Utilizzare gRPC su App Service di Azure
Evitare il flickering dei componenti nel prerender di Blazor 8
Effettuare il binding di date in Blazor
Generare HTML a runtime a partire da un componente Razor in ASP.NET Core
Migliorare la sicurezza dei prompt con Azure AI Studio
Creare un'applicazione React e configurare Tailwind CSS
Supporto ai tipi DateOnly e TimeOnly in Entity Framework Core
I più letti di oggi
- Simulare Azure Cosmos DB in locale con Docker
- Utilizzare il metodo Index di LINQ per scorrere una lista sapendo anche l'indice dell'elemento
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- .NET Conference Italia 2024 - Milano
- .NET Conference Italia 2023 - Milano e Online