Razor è un engine di templating estremamente versatile; lo usiamo ogni giorno per realizzare le view delle applicazioni ASP.NET MVC, ma in realtà può essere sfruttato anche per altri scopi. Per esempio, può essere molto comodo creare dei file cshtml o vbhtml per descrivere template di email o file di report:
@model Customer <html> <body> <p>Ciao, @this.Model.Name</p> <p>ti scriviamo questa mail per dimostrare quanto Razor sia versatile!</p> </body> </html>
Questo tipo di contenuto, a differenza di una normale view, dovrà essere renderizzato all'interno di una variabile string, così che possiamo poi effettivamente utilizzarlo come body del messaggio email. Per questo scopo, possiamo realizzare un extension method simile al seguente, che accetti in ingresso il nome della view e l'istanza del model:
public static string ViewToString<T>(this Controller controller, string viewName, T model) { var controllerContext = new ControllerContext( controller.HttpContext, controller.RouteData, controller); var viewResult = ViewEngines.Engines.FindPartialView(controllerContext, viewName); using (var sw = new StringWriter()) { var viewContext = new ViewContext( controllerContext, viewResult.View, new ViewDataDictionary<T>(), new TempDataDictionary<T>(), sw); viewContext.ViewData.Model = model; try { viewResult.View.Render(viewContext, sw); } finally { viewResult.ViewEngine.ReleaseView(controllerContext, viewResult.View); } return sw.ToString(); } }
Gran parte del metodo consiste nella ricostruzione del contesto di esecuzione, costituito da ControllerContext e ViewContext, necessari a Razor per effettuare il rendering della view. Una volta recuperata la view in base al nome, proprio tramite il ViewContext, possiamo associare il model passato in ingresso.
Una volta che tutte queste variabili sono create, possiamo finalmente invocare il metodo Render e scrivere su uno StringWriter il risultato del rendering.
L'utilizzo di questo metodo è estremamente comodo e semplice:
public ActionResult SendEmail(...) { var customer = new Customer() { Name = "Marco De Sanctis" }; string body = this.ViewToString("emailTemplate", customer); // invio email qui ... }
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Sviluppare un'interfaccia utente in React con Tailwind CSS e Preline UI
Filtrare e rimuovere gli elementi dalla cache del browser tramite le API JavaScript
Eseguire una GroupBy per entity in Entity Framework
Utilizzare HiLo per ottimizzare le insert in un database con Entity Framework
Ottimizzazione dei block template in Angular 17
Creazione di plugin per Tailwind CSS: espandere le Funzionalità del Framework
Utilizzare politiche di resiliency con Azure Container App
Utilizzare Tailwind CSS all'interno di React: installazione
Come migrare da una form non tipizzata a una form tipizzata in Angular
Usare un KeyedService di default in ASP.NET Core 8
Assegnare un valore di default a un parametro di una lambda in C#
Short-circuiting della Pipeline in ASP.NET Core
I più letti di oggi
- annunciato #netstandard 2.1. .NET Core lo supporterà a partire da #netcore3, così come le prossime versione di #xamarin, #mono e #unity.il supporto per #netfx 4.8, invece, non ci sarà. https://aspit.co/bq2
- Steel Style CheckBox per Silverlight 4.0
- Supporto ai tipi DateOnly e TimeOnly in Entity Framework Core
- Utilizzare Docker Compose con Azure App Service