składnik ASP.NET Core BlazorQuickGrid
Składnik QuickGrid
jest składnikiem umożliwiającym Razor szybkie i wydajne wyświetlanie danych w formie tabelarycznej. QuickGrid
Udostępnia prosty i wygodny składnik siatki danych dla typowych scenariuszy renderowania siatki i służy jako architektura referencyjna i punkt odniesienia wydajności dla składników siatki danych. QuickGrid
jest wysoce zoptymalizowany i wykorzystuje zaawansowane techniki w celu uzyskania optymalnej wydajności renderowania.
Pakiet
Dodaj odwołanie do Microsoft.AspNetCore.Components.QuickGrid
pakietu.
Uwaga
Aby uzyskać instrukcje dodawania pakietów do aplikacji .NET, zobacz artykuły w sekcji Instalowanie pakietów i zarządzanie nimi w temacie Przepływ pracy użycia pakietów (dokumentacja programu NuGet). Sprawdź prawidłowe wersje pakietów pod adresem NuGet.org.
Przykładowa aplikacja
Aby zapoznać się z różnymi QuickGrid
pokazami, zobacz quickGrid dla Blazor przykładowej aplikacji. Witryna demonstracyjna jest hostowana w witrynie GitHub Pages. Witryna ładuje się szybko dzięki statycznym prerenderingowi przy użyciu projektu GitHub obsługiwanego BlazorWasmPrerendering.Build
przez społeczność.
QuickGrid
implementacja
Aby zaimplementować QuickGrid
składnik:
- Określ tagi składnika
QuickGrid
w Razor adiustacji (<QuickGrid>...</QuickGrid>
). - Nadaj siatce nazwę możliwe do utworzenia zapytania źródło danych. Użyj jednego z następujących źródeł danych:
- Items: dopuszczana
IQueryable<TGridItem>
wartość null , gdzieTGridItem
jest typem danych reprezentowanych przez każdy wiersz w siatce. - ItemsProvider: wywołanie zwrotne, które dostarcza dane dla siatki.
- Items: dopuszczana
- Class: opcjonalna nazwa klasy CSS. Jeśli zostanie podana, nazwa klasy jest uwzględniona w atrybucie
class
renderowanej tabeli. - Theme: Nazwa motywu (wartość domyślna:
default
). Ma to wpływ na reguły stylów zgodne z tabelą. - Virtualize: Jeśli wartość true, siatka jest renderowana przy użyciu wirtualizacji. Jest to zwykle używane w połączeniu z przewijaniem i powoduje pobranie siatki i renderowanie tylko danych wokół bieżącego widoku przewijania. Może to znacznie poprawić wydajność podczas przewijania dużych zestawów danych. Jeśli używasz Virtualizemetody , należy podać wartość ItemSize dla parametru i upewnić się, że każdy wiersz jest renderowany ze stałą wysokością. Ogólnie rzecz biorąc, zaleca się nie używać Virtualize , jeśli ilość renderowanych danych jest mała lub jeśli używasz stronicowania.
- ItemSize: dotyczy tylko w przypadku używania polecenia Virtualize. ItemSize definiuje oczekiwaną wysokość w pikselach dla każdego wiersza, umożliwiając mechanizmowi wirtualizacji pobranie prawidłowej liczby elementów odpowiadających rozmiarowi wyświetlania i zapewnienie dokładnego przewijania.
- ItemKey: Opcjonalnie definiuje wartość dla
@key
każdego renderowanego wiersza. Zazwyczaj służy do określania unikatowego identyfikatora, takiego jak wartość klucza podstawowego, dla każdego elementu danych. Dzięki temu siatka może zachować skojarzenie między elementami wiersza i elementami danych na podstawie ich unikatowych identyfikatorów, nawet jeśliTGridItem
wystąpienia są zastępowane przez nowe kopie (na przykład po nowym zapytaniu względem bazowego magazynu danych). Jeśli nie zostanie ustawiona@key
, jest toTGridItem
wystąpienie. OverscanCount
: definiuje liczbę dodatkowych elementów do renderowania przed i po widocznym regionie w celu zmniejszenia częstotliwości renderowania podczas przewijania. Chociaż wyższe wartości mogą poprawić płynność przewijania przez renderowanie większej liczby elementów poza ekranem, wyższa wartość może również spowodować wzrost początkowych czasów ładowania. Zalecane jest znalezienie równowagi na podstawie rozmiaru zestawu danych i wymagań dotyczących środowiska użytkownika. Domyślna wartość wynosi 3. Dostępne tylko w przypadku korzystania z programu Virtualize.- Pagination: opcjonalnie łączy to
TGridItem
wystąpienie z modelem PaginationState , co powoduje pobranie siatki i renderowanie tylko bieżącej strony danych. Jest to zwykle używane w połączeniu ze składnikiem lub inną logiką Paginator interfejsu użytkownika, która wyświetla i aktualizuje podane PaginationState wystąpienie. - W zawartości podrzędnej
QuickGrid
(RenderFragment) określ PropertyColumn<TGridItem,TProp>s, które reprezentująTGridItem
kolumny, których komórki wyświetlają wartości:- Property: definiuje wartość, która ma być wyświetlana w komórkach tej kolumny.
- Format: opcjonalnie określa ciąg formatu dla wartości. Użycie Format polecenia wymaga
TProp
zaimplementowania IFormattabletypu . - Sortable: wskazuje, czy dane powinny być sortowalne według tej kolumny. Wartość domyślna może się różnić w zależności od typu kolumny. Na przykład element TemplateColumn<TGridItem> jest sortowany, jeśli określono jakikolwiek SortBy parametr.
- InitialSortDirection: wskazuje kierunek sortowania, jeśli IsDefaultSortColumn ma wartość
true
. - IsDefaultSortColumn: wskazuje, czy ta kolumna ma być sortowana domyślnie.
- PlaceholderTemplate: Jeśli określono, zwirtualizowane siatki używają tego szablonu do renderowania komórek, których dane nie zostały załadowane.
- HeaderTemplate: opcjonalny szablon komórki nagłówka tej kolumny. Jeśli nie zostanie określony, domyślny szablon nagłówka zawiera Titleelement , wraz z dowolnymi odpowiednimi wskaźnikami sortowania i przyciskami opcji.
- Title: tekst tytułu kolumny. Tytuł jest renderowany automatycznie, jeśli HeaderTemplate nie jest używany.
- Określ tagi składnika
QuickGrid
w Razor adiustacji (<QuickGrid>...</QuickGrid>
). - Nadaj siatce nazwę możliwe do utworzenia zapytania źródło danych. Użyj jednego z następujących źródeł danych:
- Items: dopuszczana
IQueryable<TGridItem>
wartość null , gdzieTGridItem
jest typem danych reprezentowanych przez każdy wiersz w siatce. - ItemsProvider: wywołanie zwrotne, które dostarcza dane dla siatki.
- Items: dopuszczana
- Class: opcjonalna nazwa klasy CSS. Jeśli zostanie podana, nazwa klasy jest uwzględniona w atrybucie
class
renderowanej tabeli. - Theme: Nazwa motywu (wartość domyślna:
default
). Ma to wpływ na reguły stylów zgodne z tabelą. - Virtualize: Jeśli wartość true, siatka jest renderowana przy użyciu wirtualizacji. Jest to zwykle używane w połączeniu z przewijaniem i powoduje pobranie siatki i renderowanie tylko danych wokół bieżącego widoku przewijania. Może to znacznie poprawić wydajność podczas przewijania dużych zestawów danych. Jeśli używasz Virtualizemetody , należy podać wartość ItemSize dla parametru i upewnić się, że każdy wiersz jest renderowany ze stałą wysokością. Ogólnie rzecz biorąc, zaleca się nie używać Virtualize , jeśli ilość renderowanych danych jest mała lub jeśli używasz stronicowania.
- ItemSize: dotyczy tylko w przypadku używania polecenia Virtualize. ItemSize definiuje oczekiwaną wysokość w pikselach dla każdego wiersza, umożliwiając mechanizmowi wirtualizacji pobranie prawidłowej liczby elementów odpowiadających rozmiarowi wyświetlania i zapewnienie dokładnego przewijania.
- ItemKey: Opcjonalnie definiuje wartość dla
@key
każdego renderowanego wiersza. Zazwyczaj służy do określania unikatowego identyfikatora, takiego jak wartość klucza podstawowego, dla każdego elementu danych. Dzięki temu siatka może zachować skojarzenie między elementami wiersza i elementami danych na podstawie ich unikatowych identyfikatorów, nawet jeśliTGridItem
wystąpienia są zastępowane przez nowe kopie (na przykład po nowym zapytaniu względem bazowego magazynu danych). Jeśli nie zostanie ustawiona@key
, jest toTGridItem
wystąpienie. - Pagination: opcjonalnie łączy to
TGridItem
wystąpienie z modelem PaginationState , co powoduje pobranie siatki i renderowanie tylko bieżącej strony danych. Jest to zwykle używane w połączeniu ze składnikiem lub inną logiką Paginator interfejsu użytkownika, która wyświetla i aktualizuje podane PaginationState wystąpienie. - W zawartości podrzędnej
QuickGrid
(RenderFragment) określ PropertyColumn<TGridItem,TProp>s, które reprezentująTGridItem
kolumny, których komórki wyświetlają wartości:- Property: definiuje wartość, która ma być wyświetlana w komórkach tej kolumny.
- Format: opcjonalnie określa ciąg formatu dla wartości. Użycie Format polecenia wymaga
TProp
zaimplementowania IFormattabletypu . - Sortable: wskazuje, czy dane powinny być sortowalne według tej kolumny. Wartość domyślna może się różnić w zależności od typu kolumny. Na przykład element TemplateColumn<TGridItem> jest sortowany, jeśli określono jakikolwiek SortBy parametr.
- InitialSortDirection: wskazuje kierunek sortowania, jeśli IsDefaultSortColumn ma wartość
true
. - IsDefaultSortColumn: wskazuje, czy ta kolumna ma być sortowana domyślnie.
- PlaceholderTemplate: Jeśli określono, zwirtualizowane siatki używają tego szablonu do renderowania komórek, których dane nie zostały załadowane.
- HeaderTemplate: opcjonalny szablon komórki nagłówka tej kolumny. Jeśli nie zostanie określony, domyślny szablon nagłówka zawiera Titleelement , wraz z dowolnymi odpowiednimi wskaźnikami sortowania i przyciskami opcji.
- Title: tekst tytułu kolumny. Tytuł jest renderowany automatycznie, jeśli HeaderTemplate nie jest używany.
Dodaj na przykład następujący składnik, aby renderować siatkę.
W przypadku Blazor Web Apps składnik musi przyjąć tryb renderowania interaktywnego, QuickGrid
aby włączyć funkcje interaktywne, takie jak stronicowanie i sortowanie.
PromotionGrid.razor
:
@page "/promotion-grid"
@using Microsoft.AspNetCore.Components.QuickGrid
<PageTitle>Promotion Grid</PageTitle>
<h1>Promotion Grid Example</h1>
<QuickGrid Items="people">
<PropertyColumn Property="@(p => p.PersonId)" Sortable="true" />
<PropertyColumn Property="@(p => p.Name)" Sortable="true" />
<PropertyColumn Property="@(p => p.PromotionDate)" Format="yyyy-MM-dd" Sortable="true" />
</QuickGrid>
@code {
private record Person(int PersonId, string Name, DateOnly PromotionDate);
private IQueryable<Person> people = new[]
{
new Person(10895, "Jean Martin", new DateOnly(1985, 3, 16)),
new Person(10944, "António Langa", new DateOnly(1991, 12, 1)),
new Person(11203, "Julie Smith", new DateOnly(1958, 10, 10)),
new Person(11205, "Nur Sari", new DateOnly(1922, 4, 27)),
new Person(11898, "Jose Hernandez", new DateOnly(2011, 5, 3)),
new Person(12130, "Kenji Sato", new DateOnly(2004, 1, 9)),
}.AsQueryable();
}
@page "/promotion-grid"
@using Microsoft.AspNetCore.Components.QuickGrid
<PageTitle>Promotion Grid</PageTitle>
<h1>Promotion Grid Example</h1>
<QuickGrid Items="people">
<PropertyColumn Property="@(p => p.PersonId)" Sortable="true" />
<PropertyColumn Property="@(p => p.Name)" Sortable="true" />
<PropertyColumn Property="@(p => p.PromotionDate)" Format="yyyy-MM-dd" Sortable="true" />
</QuickGrid>
@code {
private record Person(int PersonId, string Name, DateOnly PromotionDate);
private IQueryable<Person> people = new[]
{
new Person(10895, "Jean Martin", new DateOnly(1985, 3, 16)),
new Person(10944, "António Langa", new DateOnly(1991, 12, 1)),
new Person(11203, "Julie Smith", new DateOnly(1958, 10, 10)),
new Person(11205, "Nur Sari", new DateOnly(1922, 4, 27)),
new Person(11898, "Jose Hernandez", new DateOnly(2011, 5, 3)),
new Person(12130, "Kenji Sato", new DateOnly(2004, 1, 9)),
}.AsQueryable();
}
Uzyskaj dostęp do składnika w przeglądarce w ścieżce /promotion-grid
względnej .
Nie ma bieżących planów rozszerzenia QuickGrid
z funkcjami, które pełnowymiarowe siatki komercyjne mają tendencję do oferowania, na przykład wierszy hierarchicznych, przeciągania do zmiany kolejności kolumn lub wyboru zakresu przypominającego program Excel. Jeśli potrzebujesz zaawansowanych funkcji, których nie chcesz tworzyć samodzielnie, kontynuuj korzystanie z sieci innych firm.
Sortuj według kolumny
Składnik QuickGrid
może sortować elementy według kolumn. W Blazor Web Appprogramie s sortowanie wymaga, aby składnik przyjął tryb renderowania interaktywnego.
Dodaj Sortable="true"
(Sortable) do tagu PropertyColumn<TGridItem,TProp> :
<PropertyColumn Property="..." Sortable="true" />
W uruchomionej aplikacji posortuj kolumnę QuickGrid
, wybierając tytuł renderowanej kolumny.
Elementy strony ze składnikiem Paginator
Składnik QuickGrid
może stronicować dane ze źródła danych. W Blazor Web Apps stronicowanie wymaga, aby składnik przyjął tryb renderowania interakcyjnego.
PaginationState Dodaj wystąpienie do bloku składnika@code
. ItemsPerPage Ustaw wartość na liczbę elementów do wyświetlenia na stronę. W poniższym przykładzie wystąpienie ma nazwę pagination
, a dziesięć elementów na stronę jest ustawionych:
PaginationState pagination = new PaginationState { ItemsPerPage = 10 };
QuickGrid
Ustaw właściwość składnika Pagination na :pagination
<QuickGrid Items="..." Pagination="pagination">
Aby udostępnić interfejs użytkownika na potrzeby stronicowania, dodaj Paginator
składnik powyżej lub poniżej QuickGrid
składnika. Ustaw wartość na Paginator.State pagination
:
<Paginator State="pagination" />
W uruchomionej aplikacji przejdź do strony elementów przy użyciu renderowanego Paginator
składnika.
Atrybuty niestandardowe i style
Usługa QuickGrid obsługuje również przekazywanie atrybutów niestandardowych i klas stylów (Class) do renderowanego elementu tabeli:
<QuickGrid Items="..." custom-attribute="value" Class="custom-class">
Źródło danych programu Entity Framework Core (EF Core)
Użyj wzorca fabryki, aby rozpoznać EF Core kontekst bazy danych, który dostarcza dane do QuickGrid
składnika. Aby uzyskać więcej informacji na temat tego, dlaczego wzorzec fabryki jest zalecany, zobacz ASP.NET Core Blazor z platformą Entity Framework Core (EF Core).
Fabryka kontekstu bazy danych (IDbContextFactory<TContext>) jest wstrzykiwana do składnika za pomocą @inject
dyrektywy . Podejście fabryczne wymaga usunięcia kontekstu bazy danych, więc składnik implementuje IAsyncDisposable interfejs z dyrektywą @implements
. Dostawca elementu dla QuickGrid
składnika jest uzyskiwany DbSet<T>
z utworzonego kontekstu bazy danych (CreateDbContext) fabryki kontekstu wstrzykniętej bazy danych.
Usługa QuickGrid rozpoznaje wystąpienia dostarczone przez IQueryable platformę EF i wie, jak asynchronicznie rozwiązywać zapytania pod kątem wydajności.
Dodaj odwołanie do Microsoft.AspNetCore.Components.QuickGrid.EntityFrameworkAdapter
pakietu NuGet.
Uwaga
Aby uzyskać instrukcje dodawania pakietów do aplikacji .NET, zobacz artykuły w sekcji Instalowanie pakietów i zarządzanie nimi w temacie Przepływ pracy użycia pakietów (dokumentacja programu NuGet). Sprawdź prawidłowe wersje pakietów pod adresem NuGet.org.
Wywołaj AddQuickGridEntityFrameworkAdapter kolekcję usług w pliku w Program
celu zarejestrowania implementacji obsługującej IAsyncQueryExecutor platformę EF:
builder.Services.AddQuickGridEntityFrameworkAdapter();
W poniższym przykładzie użyto ExampleTable
DbSet<TEntity> (tabeli) z AppDbContext
kontekstu bazy danych (context
) jako źródła danych dla QuickGrid
składnika:
@using Microsoft.AspNetCore.Components.QuickGrid
@using Microsoft.EntityFrameworkCore
@implements IAsyncDisposable
@inject IDbContextFactory<AppDbContext> DbFactory
...
<QuickGrid ... Items="context.ExampleTable" ...>
...
</QuickGrid>
@code {
private AppDbContext context = default!;
protected override void OnInitialized()
{
context = DbFactory.CreateDbContext();
}
public async ValueTask DisposeAsync() => await context.DisposeAsync();
}
W bloku kodu (@code
) poprzedniego przykładu:
- Pole
context
zawiera kontekst bazy danych, wpisany jakoAppDbContext
. - Metoda
OnInitialized
cyklu życia przypisuje nowy kontekst bazy danych (CreateDbContext) docontext
pola z iniekcyjnej fabryki (DbFactory
). - Metoda asynchroniczna
DisposeAsync
usuwa kontekst bazy danych po usunięciu składnika.
Możesz również użyć dowolnego operatora LINQ obsługiwanego przez platformę EF do filtrowania danych przed przekazaniem ich do parametru Items .
Poniższy przykład filtruje filmy według tytułu filmu wprowadzonego w polu wyszukiwania. Kontekst bazy danych to BlazorWebAppMoviesContext
, a model to Movie
. Właściwość filmu Title
jest używana do operacji filtrowania.
@using Microsoft.AspNetCore.Components.QuickGrid
@using Microsoft.EntityFrameworkCore
@implements IAsyncDisposable
@inject IDbContextFactory<BlazorWebAppMoviesContext> DbFactory
...
<p>
<input type="search" @bind="titleFilter" @bind:event="oninput" />
</p>
<QuickGrid ... Items="FilteredMovies" ...>
...
</QuickGrid>
@code {
private string titleFilter = string.Empty;
private BlazorWebAppMoviesContext context = default!;
protected override void OnInitialized()
{
context = DbFactory.CreateDbContext();
}
private IQueryable<Movie> FilteredMovies =>
context.Movie.Where(m => m.Title!.Contains(titleFilter));
public async ValueTask DisposeAsync() => await context.DisposeAsync();
}
Obsługa nazw wyświetlanych
Tytuł kolumny można przypisać przy użyciu ColumnBase<TGridItem>.Title tagu PropertyColumn<TGridItem,TProp>.s. W poniższym przykładzie filmu kolumna ma nazwę "Release Date
" dla danych daty premiery filmu w kolumnie:
<PropertyColumn Property="movie => movie.ReleaseDate" Title="Release Date" />
Jednak zarządzanie tytułami kolumn (nazwami) z powiązanych właściwości modelu jest zwykle lepszym wyborem do obsługi aplikacji. Model może kontrolować nazwę wyświetlaną właściwości za pomocą atrybutu [Display]
. W poniższym przykładzie model określa nazwę wyświetlaną daty wydania filmu "Release Date
" dla jej ReleaseDate
właściwości:
[Display(Name = "Release Date")]
public DateTime ReleaseDate { get; set; }
Aby umożliwić QuickGrid
składnikowi używanie klasy , podklasy DisplayAttribute.NamePropertyColumn<TGridItem,TProp> w składniku lub w oddzielnej klasie:
public class DisplayNameColumn<TGridItem, TProp> : PropertyColumn<TGridItem, TProp>
{
protected override void OnParametersSet()
{
if (Title is null && Property.Body is MemberExpression memberExpression)
{
var memberInfo = memberExpression.Member;
Title =
memberInfo.GetCustomAttribute<DisplayNameAttribute>().DisplayName ??
memberInfo.GetCustomAttribute<DisplayAttribute>().Name ??
memberInfo.Name;
}
base.OnParametersSet();
}
}
Użyj podklasy w składniku QuickGrid
. W poniższym przykładzie jest używana poprzednia ilustracja DisplayNameColumn
. Nazwa "Release Date
" jest dostarczana przez [Display]
atrybut w modelu, więc nie ma potrzeby określania elementu Title:
<DisplayNameColumn Property="movie => movie.ReleaseDate" />
Atrybut [DisplayName]
jest również obsługiwany:
[DisplayName("Release Date")]
public DateTime ReleaseDate { get; set; }
Jednak atrybut jest zalecany, [Display]
ponieważ udostępnia dodatkowe właściwości. Na przykład [Display]
atrybut oferuje możliwość przypisania typu zasobu do lokalizacji.
Dane zdalne
W Blazor WebAssembly aplikacjach pobieranie danych z internetowego interfejsu API opartego na formacie JSON na serwerze jest typowym wymaganiem. Aby pobrać tylko dane wymagane dla bieżącej strony/widokuport danych i zastosować reguły sortowania lub filtrowania na serwerze, użyj parametru ItemsProvider .
ItemsProvider można również użyć w aplikacji po stronie Blazor serwera, jeśli aplikacja jest wymagana do wykonywania zapytań dotyczących zewnętrznego punktu końcowego lub w innych przypadkach, w których wymagania nie są objęte programem IQueryable.
Podaj wywołanie zwrotne zgodne z typem delegata GridItemsProvider<TGridItem> , gdzie TGridItem
jest typem danych wyświetlanych w siatce. Wywołanie zwrotne otrzymuje parametr typu GridItemsProviderRequest<TGridItem>, który określa indeks początkowy, maksymalną liczbę wierszy i kolejność sortowania danych do zwrócenia. Oprócz zwracania pasujących elementów całkowita liczba elementów (totalItemCount
) jest również wymagana do poprawnego działania stronicowania i wirtualizacji.
Poniższy przykład pobiera dane z publicznej bazy danych OpenFDA Food Enforcement.
Element GridItemsProvider<TGridItem> konwertuje GridItemsProviderRequest<TGridItem> element na zapytanie względem bazy danych OpenFDA. Parametry zapytania są tłumaczone na określony format adresu URL obsługiwany przez zewnętrzny interfejs API JSON. Sortowanie i filtrowanie można wykonywać tylko za pomocą sortowania i filtrowania obsługiwanego przez zewnętrzny interfejs API. Punkt końcowy OpenFDA nie obsługuje sortowania, więc żadna z kolumn nie jest oznaczona jako sortowalna. Jednak obsługuje pomijanie rekordów (skip
parametru) i ograniczanie zwracania rekordów (limit
parametru), więc składnik może włączyć wirtualizację i szybko przewijać dziesiątki tysięcy rekordów.
FoodRecalls.razor
:
@page "/food-recalls"
@inject HttpClient Http
@inject NavigationManager Navigation
<PageTitle>Food Recalls</PageTitle>
<h1>OpenFDA Food Recalls</h1>
<div class="grid" tabindex="-1">
<QuickGrid ItemsProvider="@foodRecallProvider" Virtualize="true">
<PropertyColumn Title="ID" Property="@(c => c.Event_Id)" />
<PropertyColumn Property="@(c => c.State)" />
<PropertyColumn Property="@(c => c.City)" />
<PropertyColumn Title="Company" Property="@(c => c.Recalling_Firm)" />
<PropertyColumn Property="@(c => c.Status)" />
</QuickGrid>
</div>
<p>Total: <strong>@numResults results found</strong></p>
@code {
private GridItemsProvider<FoodRecall>? foodRecallProvider;
private int numResults;
protected override async Task OnInitializedAsync()
{
foodRecallProvider = async req =>
{
var url = Navigation.GetUriWithQueryParameters(
"https://api.fda.gov/food/enforcement.json",
new Dictionary<string, object?>
{
{ "skip", req.StartIndex },
{ "limit", req.Count },
});
var response = await Http.GetFromJsonAsync<FoodRecallQueryResult>(
url, req.CancellationToken);
return GridItemsProviderResult.From(
items: response!.Results,
totalItemCount: response!.Meta.Results.Total);
};
numResults = (await Http.GetFromJsonAsync<FoodRecallQueryResult>(
"https://api.fda.gov/food/enforcement.json"))!.Meta.Results.Total;
}
}
Aby uzyskać więcej informacji na temat wywoływania internetowych interfejsów API, zobacz Wywoływanie internetowego interfejsu API z aplikacji ASP.NET CoreBlazor.
QuickGrid
rusztowanie
Szkielet QuickGrid
szkieletu Razor z elementami umożliwiającymi QuickGrid
wyświetlanie danych z bazy danych.
Szkielet generuje podstawowe strony tworzenia, odczytu, aktualizacji i usuwania (CRUD) na podstawie modelu danych platformy Entity Framework Core. Można szkieletować poszczególne strony lub wszystkie strony CRUD. W razie potrzeby należy wybrać klasę modelu i DbContext
wartość , opcjonalnie tworząc nową DbContext
.
Składniki szkieletowe Razor są dodawane do projektu w wygenerowanym folderze o nazwie po klasie modelu. Wygenerowany Index
składnik używa QuickGrid
składnika do wyświetlania danych. Dostosuj wygenerowane składniki zgodnie z potrzebami i włącz interakcyjność, aby korzystać z interaktywnych funkcji, takich jak stronicowanie, sortowanie i filtrowanie .
Składniki tworzone przez szkielet wymagają renderowania po stronie serwera (SSR), więc nie są obsługiwane podczas uruchamiania w zestawie WebAssembly.
Kliknij prawym przyciskiem myszy Components/Pages
folder i wybierz polecenie Dodaj>nowy element szkieletowy.
Po otwarciu okna dialogowego Dodawanie nowego elementu szkieletu w celu zainstalowania>wspólnego>>BlazorRazor składnika wybierz pozycję Razor Składniki przy użyciu programu Entity Framework (CRUD). Kliknij przycisk Dodaj.
CRUD to skrót od tworzenia, odczytu, aktualizacji i usuwania. Szkielet tworzy składniki tworzenia, edytowania, usuwania, szczegółów i indeksowania aplikacji.
Ukończ okno dialogowe Dodawanie Razor składników przy użyciu programu Entity Framework (CRUD):
- Lista rozwijana Szablon zawiera inne szablony służące do tworzenia, edytowania, usuwania, szczegółów i składników listy. Ta lista rozwijana jest przydatna, gdy trzeba utworzyć tylko określony typ szkieletu składnika do klasy modelu. Pozostaw listę rozwijaną Szablon ustawioną na CRUD, aby utworzyć szkielet pełnego zestawu składników.
- Z listy rozwijanej Klasa modelu wybierz klasę modelu. Folder jest tworzony dla wygenerowanych składników z nazwy modelu (jeśli klasa modelu nosi nazwę
Movie
, folder jest automatycznie nazwany ).MoviePages
- W przypadku klasy DbContext wybierz istniejący kontekst bazy danych lub wybierz + przycisk (znak plus) i okno dialogowe modalne Dodaj kontekst danych , aby dodać nowy kontekst bazy danych.
- Po zamknięciu okna dialogowego modelu lista rozwijana Dostawca bazy danych jest domyślnie ustawiona na program SQL Server. Możesz wybrać odpowiedniego dostawcę dla używanej bazy danych. Dostępne opcje to SQL Server, SQLite, PostgreSQL i Azure Cosmos DB.
- Wybierz Dodaj.