Finora abbiamo sempre visto QuickGrid dal punto di vista della consultazione dati. Questo perché, fondamentalmente, questa griglia è un componente read only, senza supporto nativo alla scrittura.
Tuttavia, se dobbiamo creare delle pagine CRUD piuttosto standard e se stiamo utilizzando Entity Framework (e pertanto siamo in un contesto di Server Interactivity), possiamo usare lo scaffolding di Visual Studio per generare queste pagine automaticamente.
Con un click sul tasto destro su una directory qualsiasi del progetto Blazor, dobbiamo selezionare Add -> New Scaffolded Item, e successivamente Razor Pages using Entity Framework:

Nella successiva pagina del Wizard, dobbiamo indicare quale entity vogliamo gestire e, ovviamente, il DbContext da utilizzare:

A questo punto, lo scaffolder creerà una serie di pagine per le tipiche operazioni CRUD: Index, Edit, Create, Details e Delete.
Per esempio, la pagina Index conterrà la lista delle nostre entity, ovviamente basata su QuickGrid - e che potremo personalizzare secondo le nostre necessità:
@page "/shares"
@using Microsoft.AspNetCore.Components.QuickGrid
@inject BlazorQuickGrid.Data.MyContext DB
@using BlazorQuickGrid.Data
<PageTitle>Index</PageTitle>
<h1>Index</h1>
<p> <a href="shares/create">Create New</a></p>
<QuickGrid Class="table" Items="DB.Shares">
<PropertyColumn Property="share => share.CompanyName" />
<PropertyColumn Property="share => share.Value" />
<TemplateColumn Context="share">
<a href="@($"shares/edit?id={share.Id}")">Edit</a> |
<a href="@($"shares/details?id={share.Id}")">Details</a> |
<a href="@($"shares/delete?id={share.Id}")">Delete</a>
</TemplateColumn>
</QuickGrid>
Il risultato finale, seppure magari un po' semplicistico, ci permette di risparmiare un sacco di tempo ed è comunque funzionale - per esempio - per realizzare velocemente un back office:

Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Ottimizzare le API in ASP.NET con Feature Flags
Realizzare un accordion con gli elementi HTML details e summary
Mappare una complex property di una entity su un campo JSON
Centralizzare e governare MCP server e Skill con Azure API Center
Ottimizzare la content-visibility in CSS specificando lo spazio da occupato dall'area non renderizzata
Creare espressioni riutilizzabili nelle query LINQ per Entity Framework
Usare la libreria PredicateBuilder per eseguire query tramite Entity Framework che usano or su più campi
Mischiare codice server side e client side in una query LINQ con Entity Framework
Gestione ciclo di vita in .NET Aspire
Stop Building Chatbots. Build a team
Running workloads and operations with Azure Kubernetes Service


