syncfusion-blazor-datagrid
Implementing Syncfusion Blazor DataGrid
The Syncfusion Blazor DataGrid (SfGrid<TValue>) is a high-performance, feature-rich component for displaying and manipulating tabular data. It supports data binding, sorting, filtering, grouping, paging, editing, selection, aggregates, export, virtual/infinite scrolling, templates, and more.
NuGet: Syncfusion.Blazor.Grid + Syncfusion.Blazor.Themes
Namespace: Syncfusion.Blazor.Grids
When to Use This Skill
Use this skill when you need to:
- Set up and configure a DataGrid in Blazor Server, WebAssembly, Web App, or MAUI
- Bind local or remote data (OData, HTTP, SfDataManager)
- Configure columns (type, format, template, frozen, reorder, resize, chooser)
- Implement sorting, filtering (FilterBar/Menu/Excel/CheckBox), or searching
- Enable grouping with lazy load or caption templates
- Configure paging with custom templates or SfPager
- Set up virtual scrolling, infinite scrolling for large datasets
- Implement editing (Normal/Dialog/Batch/Command column) with validation
- Configure selection (row, cell, checkbox) with programmatic control
- Use clipboard copy, AutoFill, or Paste features
- Add aggregates (footer, group, caption, reactive)
- Use row/column templates, detail template, row drag-drop
- Configure toolbar, context menu, column menu, column chooser
- Export data to Excel or PDF
- Manage print functionality
- Optimize performance (SetRowDataAsync, PreventRender)
- Handle DataGrid events
- Manage state persistence (EnablePersistence)
- Customize styling and appearance
- Enable adaptive UI for mobile/responsive layouts
π Mandatory Key Rules
These rules govern how this skill MUST behave. They are mandatory and must be strictly followed.
1. Purpose and Responsibility
Your responsibility is to interpret any naturalβlanguage user request and provide:
- Accurate
- Complete
- Validated
information about all supported aspects of the Syncfusion Blazor DataGrid, including:
- Public APIs
- Properties
- Events
- Features
- Behaviors
2. Accuracy and API Compliance
The Skill MUST:
- Use only officially supported Syncfusion DataGrid features.
- NEVER invent APIs, methods, properties, events, behaviors, or future features.
- NEVER provide unsupported or hypothetical code samples.
- ALWAYS follow official Syncfusion component design patterns.
If a feature is not supported:
- Clearly state the limitation.
- Suggest a supported alternative when possible.
3. Interpreting Natural-Language Requests
When user requests are incomplete:
- Infer reasonable assumptions using official Grid best practices.
- Fill missing gaps with accurate and relevant information.
- Request clarification only when essential.
4. Response Quality Requirements
Every response MUST:
- Be technically accurate
- Be complete and wellβstructured
- Include required dependencies and configuration notes
- Follow real, documented Syncfusion API behavior
- Avoid contradictions or ambiguity
5. Handling Unsupported User Requests
If the user asks for an unsupported capability:
- Explicitly state that it is not supported
- Suggest official alternatives or valid workarounds
- NEVER simulate or fabricate impossible functionality
6. Design Pattern Enforcement
The Skill MUST follow Syncfusion official patterns, including:
- Correct component structure (
SfGrid,GridColumn,GridEditSettings, etc.) - Proper async event and API usage
- Valid configuration properties and enums
- Supported dataβbinding approaches
- Real event patterns and names
7. Quality, Completeness & Reliability
The Skill MUST:
- Use only validated and real Grid capabilities
- Provide actionable and implementationβready guidance
- Ensure clarity so users can follow without guesswork
- Maintain clean, readable, and professional formatting
8. No-Hallucination Safeguard
The Skill MUST NOT:
- Invent nonβexistent APIs or behavior
- Suggest unsupported modes, features, or configuration
- Provide incorrect, misleading, or unverifiable code
- Describe undocumented internal behavior
If unsure:
- Ask for clarification OR
- Clearly state the limitation
9. Event Name Verification Requirement
CRITICAL: Event names MUST be verified against references/events.md BEFORE providing code examples. All grid events MUST be defined inside the <GridEvents> component
Common Mistakes to Avoid:
- β
OnSortChange- Does NOT exist. UseSorting,Sortedinstead - β
OnFilterChange- Does NOT exist. UseFiltering,Filteredinstead - β
OnPageChange- Does NOT exist. UsePageChanging,PageChangedinstead - β
OnGroupChange- Does NOT exist. UseGrouping,Groupedinstead
Rule: ALWAYS cross-reference references/events.md for:
- Exact event names (case-sensitive)
- Event argument types
- Whether events are cancelable
- When they fire (before/after operation)
Verification Checklist Before Providing Event Code:
- Check if event name exists in
references/events.md - Verify the correct
EventArgstype - Confirm
Cancelablestatus (β or β) - Test against actual Syncfusion documentation
- Never assume naming conventions (e.g.,
Onprefix,Changesuffix)
Strict Rules for Grid Events
1. Event Handlers MUST be in <GridEvents> Component
- β
Define ALL event handlers inside
<GridEvents TValue="YourType"> - β
Use the exact event names as properties (e.g.,
DataBound,RowSelecting,Grouped) - β DO NOT use
@onEventNamesyntax on<SfGrid> - β DO NOT define event handlers on any root element
2. Correct Event Handler Signatures
- β
Use
async Taskfor event handlers - β
Event handlers may have specific parameter types (e.g.,
GridEventArgs,RowSelectEventArgs) - β
Some events have no parameters (e.g.,
DataBound(),Created()) - β Do not use synchronous
voidmethods for async operations
3. API Method Calls MUST NOT be in Lifecycle Events
- β DO NOT call API methods in
OnInitialized() - β DO NOT call API methods in
OnAfterRenderAsync() - β DO NOT call API methods in
OnParametersSet() - β ONLY call API methods in response to user interactions (button clicks, dropdown changes, etc.)
- β API methods CAN be called inside GridEvents handlers
4. Use Async/Await Pattern
- β
Always use
awaitwith async API methods - β
Define event handlers as
async Task - β
Mark code block methods as
async Task - β Do not use synchronous method calls for async operations
5. Grid Reference Required for API Calls
- β
Use
@ref="Grid"to get the Grid instance - β
Use the reference to call API methods (e.g.,
await Grid.GroupColumnAsync()) - β Do not attempt to call methods without a reference
6. Event Types Must Match GridEvents TValue
- β
Set
TValue="YourDataType"to match your data model - β All event handlers will be properly typed with this model
- β Do not use generic or wrong type for TValue
Navigation Guide
Setup & Getting Started
π Read: references/getting-started.md
- NuGet install,
_Imports.razor,Program.cs, theme/script setup, basic grid
π Read: references/getting-started-app-types.md
- Server App, Web App (Auto/WASM), MAUI variants
Data
π Read: references/data-binding.md
- Local (List, ExpandoObject, DynamicObject, DataTable, ObservableCollection)
Connecting to Adaptors (Remote Data)
π Read: references/odatav4-adaptor.md
- OData V4 service setup, ODataConventionModelBuilder, [EnableQuery], automatic $filter/$orderby/$skip/$top, CRUD with PATCH/DELETE
π Read: references/web-api-adaptor.md
- Web API with { Items, Count } response, manual $filter/$orderby/$skip/$top QueryString parsing, CRUD with GET/POST/PUT/DELETE
π Read: references/url-adaptor.md
- Custom API with { result, count } response, DataManagerRequest POST body, DataOperations helpers, InsertUrl/UpdateUrl/RemoveUrl/CrudUrl/BatchUrl
π Read: references/custom-adaptor.md
- DataAdaptor abstract class, override Read/Insert/Update/Remove/BatchUpdate, service injection, adaptor as component, custom parameters via Query.AddParams
Columns
π Read: references/columns.md
- ColumnType, Format, TextAlign, frozen, reorder, resize, chooser, stacked headers, column menu, foreign key
π Read: references/cell.md
- QueryCellInfo, CustomAttributes, ClipMode, GridLines, tooltips
Sorting, Filtering, Searching
π Read: references/sorting.md
- AllowSorting, multi-sort, SortColumnAsync, ClearSortingAsync
π Read: references/filtering.md
- AllowFiltering, FilterType (FilterBar/Menu/Excel/CheckBox), operators, FilterByColumnAsync
π Read: references/searching.md
- Toolbar Search, SearchAsync, GridSearchSettings
Grouping & Paging
π Read: references/grouping.md
- AllowGrouping, lazy load grouping, CaptionTemplate, programmatic group/ungroup
π Read: references/paging.md
- AllowPaging, GridPageSettings, pager template, GoToPageAsync
Scrolling
π Read: references/scrolling.md
- Height/Width, sticky header, ScrollIntoViewAsync
π Read: references/virtual-scrolling.md
- EnableVirtualization, EnableColumnVirtualization, OverscanCount, limitations
π Read: references/infinite-scrolling.md
- EnableInfiniteScrolling, GridInfiniteScrollSettings, cache mode, limitations
Editing
π Read: references/editing.md
- GridEditSettings, EditMode (Normal/Dialog/Batch/CommandColumn), ValidationRules, EditType, EditTemplate, CRUD methods
Read: references/editing-patterns.md
- Cancel edit based on condition, disable editing for specific rows
- Provide new/edited item via events, default column values, new row position
- Always-show add-new-row form, delete multiple rows, single-click editing
- Save new row at a specific index, inline template editing
π Read: references/editing-validation.md
- Per-column
ValidationRules, Data Annotation attributes ([Required],[Range], etc.) - Custom validation attributes, complex type validation, custom validator component
Selection
π Read: references/selection.md
- AllowSelection, SelectionMode, SelectionType, checkbox selection, programmatic selection
π Read: references/clipboard.md
- Clipboard copy (Ctrl+C / Ctrl+Shift+H), CopyAsync, AutoFill drag handle, Paste (Ctrl+V), batch editing requirements
Aggregates
π Read: references/aggregates.md
- GridAggregates, AggregateType, FooterTemplate, GroupFooterTemplate, GroupCaptionTemplate, reactive aggregates
Row Features & Templates
π Read: references/row-features.md
- RowDataBound, row drag-drop, row height, row spanning, RowTemplate
πRead: references/templates-structural.md
- ColumnTemplate (image, hyperlink, checkbox, SfChip), HeaderTemplate, RowTemplate, RowTemplate formatting, DetailTemplate, expand/collapse APIs, expand on load, hide expand icon, custom CSS icons, hierarchical nested Grid
π Read: references/templates-interactive.md
- ToolbarTemplate, Column EditTemplate, GridEditSettings Template, disable inputs on add vs edit, triple underscore nested binding, focus editor on dialog open, RowUpdating transform, FooterTemplate, CaptionTemplate, custom Blazor component in caption, locale customization, PagerTemplate
Toolbar, Context Menu
π Read: references/toolbar.md
- Built-in/custom toolbar items, OnToolbarClick, ToolbarTemplate
π Read: references/context-menu.md
- ContextMenuItems, custom items, ContextMenuItemClicked
Export & Print
π Read: references/excel-export.md
- AllowExcelExport, ExportToExcelAsync, ExcelExportProperties, theme/template export
π Read: references/pdf-export.md
- AllowPdfExport, ExportToPdfAsync, PdfExportProperties, template PDF export
π Read: references/print.md
- PrintAsync, PrintMode
Performance, Events, State
π Read: references/performance.md
- SetRowDataAsync, PreventRender, WebAssembly optimization, column virtualization tips
π Read: references/events.md
- Complete GridEvents reference: all edit, selection, filter, sort, group, page, toolbar, export events
π Read: references/state-management.md
- EnablePersistence, GetPersistDataAsync, SetPersistDataAsync, ResetPersistDataAsync
Styling & Adaptive UI
π Read: references/style-and-appearance.md
- CSS classes for grid, header, rows, filtering, editing, grouping, aggregates
π Read: references/adaptive-layout.md
- EnableAdaptiveUI, RowRenderingMode, AdaptiveUIMode, mobile-responsive patterns
Quick Start
@page "/datagrid-demo"
@using Syncfusion.Blazor.Grids
<SfGrid DataSource="@Orders" AllowPaging="true" AllowSorting="true" AllowFiltering="true">
<GridPageSettings PageSize="10"></GridPageSettings>
<GridColumns>
<GridColumn Field="OrderID" HeaderText="Order ID" IsPrimaryKey="true" Width="120" TextAlign="TextAlign.Right"></GridColumn>
<GridColumn Field="CustomerID" HeaderText="Customer" Width="150"></GridColumn>
<GridColumn Field="Freight" HeaderText="Freight" Format="C2" Width="120" TextAlign="TextAlign.Right"></GridColumn>
<GridColumn Field="OrderDate" HeaderText="Order Date" Format="d" Width="150" Type="ColumnType.Date"></GridColumn>
<GridColumn Field="ShipCountry" HeaderText="Ship Country" Width="150"></GridColumn>
</GridColumns>
</SfGrid>
@code {
public List<Order> Orders = new List<Order>
{
new Order { OrderID = 10248, CustomerID = "VINET", Freight = 32.38, OrderDate = new DateTime(1996,7,4), ShipCountry = "France" },
new Order { OrderID = 10249, CustomerID = "TOMSP", Freight = 11.61, OrderDate = new DateTime(1996,7,5), ShipCountry = "Germany" },
};
public class Order
{
public int OrderID { get; set; }
public string CustomerID { get; set; }
public double Freight { get; set; }
public DateTime OrderDate { get; set; }
public string ShipCountry { get; set; }
}
}
Common Patterns
Grid with Editing + Toolbar
<SfGrid DataSource="@Orders" Toolbar="@(new List<string>() { "Add","Edit","Delete","Update","Cancel" })">
<GridEditSettings AllowAdding="true" AllowEditing="true" AllowDeleting="true" Mode="EditMode.Normal"></GridEditSettings>
<GridColumns>
<GridColumn Field="OrderID" IsPrimaryKey="true" ValidationRules="@(new ValidationRules{Required=true})"></GridColumn>
<GridColumn Field="CustomerID" ValidationRules="@(new ValidationRules{Required=true})"></GridColumn>
<GridColumn Field="Freight" EditType="EditType.NumericEdit"></GridColumn>
</GridColumns>
</SfGrid>
Grid with Grouping + Paging
<SfGrid DataSource="@Orders" AllowGrouping="true" AllowPaging="true">
<GridGroupSettings Columns="@(new string[]{"ShipCountry"})"></GridGroupSettings>
<GridPageSettings PageSize="10"></GridPageSettings>
<GridColumns>
<GridColumn Field="OrderID" Width="120"></GridColumn>
<GridColumn Field="CustomerID" Width="150"></GridColumn>
<GridColumn Field="ShipCountry" Width="150"></GridColumn>
</GridColumns>
</SfGrid>
Grid Reference for Programmatic Control
<SfGrid @ref="Grid" DataSource="@Orders">...</SfGrid>
@code {
SfGrid<Order> Grid;
// Programmatic operations:
// await Grid.SortColumnAsync("OrderID", SortDirection.Ascending, false);
// await Grid.FilterByColumnAsync("ShipCountry", "equal", "France");
// await Grid.GoToPageAsync(2);
// await Grid.StartEditAsync();
// await Grid.SelectRowAsync(0);
}
Key Properties at a Glance
| Property | Description |
|---|---|
DataSource |
Bind IEnumerable<T> or DataManagerRequest |
AllowPaging |
Enable paging |
AllowSorting |
Enable sorting |
AllowFiltering |
Enable column filtering |
AllowGrouping |
Enable row grouping |
AllowSelection |
Enable row/cell selection |
Height / Width |
Fixed dimensions for scrolling |
Toolbar |
Built-in or custom toolbar items |
EnableVirtualization |
Row virtualization for large data |
EnableInfiniteScrolling |
Infinite scroll loading |
EnablePersistence |
Save state to localStorage |
EnableAdaptiveUI |
Mobile-responsive rendering |