Negli scorsi script ci siamo occupati di QuickGrid, un componente di Blazor che permette di realizzare facilmente interfacce tabellari.
Nel caso in cui stiamo utilizzando Blazor Server (o la nuova server interactivity delle Blazor Web App), possiamo integrare la nostra pagina direttamente con Entity Framework, così da rendere davvero minimale il codice da scrivere. Per esempio, immaginiamo di avere un DbContext come il seguente, in cui sono definite due classi Share e Industry:
public class MyContext : DbContext { public MyContext(DbContextOptions<MyContext> options) : base(options) { } // Id, CompanyName, Value, Industry public DbSet<Share> Shares { get; set; } // Id, Name public DbSet<Industry> Industries { get; set; } }
Come al solito, dobbiamo come prima cosa registrare il DbContext nell'IoC container di ASP.NET Core:
public static void Main(string[] args) { var builder = WebApplication.CreateBuilder(args); builder.Services.AddDbContext<MyContext>(options => { options.UseSqlServer(builder.Configuration.GetConnectionString("MyContext")); }) .AddQuickGridEntityFrameworkAdapter(); // .. altro codice qui .. }
Nel codice in alto, dopo aver invocato AddDbContext e passato la connection string per il nostro database, abbiamo anche aggiunto un servizio particolare, AddQuickGridEntityFrameworkAdapter, che permette a QuickGrid di riconoscere il particolare IQueryable restituito da Entity Framework, così che possa eseguirne le query in maniera asincrona massimizzando l'efficienza del nostro codice.
Questo metodo è definito in un particolare package chiamato EntityFrameworkAdapter che dobbiamo aggiungere alle reference del progetto, ovviamente insieme a quello di QuickGrid:
dotnet add package Microsoft.AspNetCore.Components.QuickGrid dotnet add package Microsoft.AspNetCore.Components.QuickGrid.EntityFrameworkAdapter
A questo punto il gioco è fatto: tutto ciò che dobbiamo fare è iniettare in pagina il DbContext e collegarlo alla grid stessa, passando il DbSet desiderato:
@page "/companies" @inject MyContext data <QuickGrid Items="data.Shares" Pagination="@pagination"> <PropertyColumn Title="Company" Property="@(x => x.CompanyName)" Sortable="true" /> <PropertyColumn Title="Value" Property="@(x => x.Value)" Format="c" Sortable="true" /> </QuickGrid> <Paginator State="@pagination" /> @code { private PaginationState pagination = new PaginationState(); }
La griglia dello snippet supporta la paginazione e il sorting: come possiamo verificare dal log di ASP.NET Core, entrambe queste funzionalità sono implementate lato database, sfruttando le peculiarità di Entity Framework e IQueryable.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Utilizzare il metodo ExceptBy per eseguire operazione di sottrazione tra liste
Utilizzare Container Queries nominali
Ottimizzare le pull con Artifact Cache di Azure Container Registry
La gestione della riconnessione al server di Blazor in .NET 9
Utilizzare i variable font nel CSS
Utilizzare la funzione EF.Parameter per forzare la parametrizzazione di una costante con Entity Framework
Introduzione ai web component HTML
Utilizzare il metodo CountBy di LINQ per semplificare raggruppamenti e i conteggi
Creare una custom property in GitHub
Supportare la sessione affinity di Azure App Service con Application Gateway
Referenziare un @layer più alto in CSS
Applicare un filtro per recuperare alcune issue di GitHub
I più letti di oggi
- .NET Conference Italia 2018 - Milano
- Tutorial ASP.NET
- Seconda preview per i Dynamic Data Control 4.0
- Disponibile al download la versione finale di Mozilla Firefox 4
- Microsoft Security Bulletin MS02-044
- Shared Source Initiative per gli MVP
- Mono 1.1.10 per un po' di ASP.NET 2.0
- Webcast 'ASP.NET 2.0 HttpRuntime'