TableView/DataGrid control for WinUI.
$ dotnet add package WinUI.TableViewWinUI.TableView is a lightweight and fast data grid control made for WinUI apps and now supports the Uno Platform. It is easy to use, and capable of handling large numbers of items with a focus on performance. It's derived from ListView so you will experience fluent look and feel in your project. It comes with all the essential features you need, plus extras like an Excel like column filter, options buttons (for columns and the TableView) and easy data export.
Explore the interactive WinUI.TableView samples with code snippets in a Samples App on Microsoft Store or Uno Platorm WASM:

ShowExportOptions = true.RowDetailsTemplate.RowHeaderTemplate.WinUI.TableView is compatible with the Uno Platform, enabling you to use the control across multiple platforms.
Try the Uno WASM Sample App here 👉 https://tableview.samples.w-ahmad.dev/
If you don't already have a WinUI 3 project or Uno prject, create one in Visual Studio.
Inatall WinUI.TableView NuGet package to your app with your preferred method. Here is the one using NuGet Package Manager:
Install-Package WinUI.TableView
WinUI.TableView to Your XAMLIn your MainWindow.xaml, add the WinUI.TableView control:
<Window
x:Class="App1.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="using:App1"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"
xmlns:tv="using:WinUI.TableView">
<Grid>
<tv:TableView x:Name="MyTableView"
ItemsSource="{x:Bind ViewModel.Items}" />
</Grid>
</Window>
TableViewIn your MainPage.xaml.cs, set up the data context and bind data to the TableView:
public sealed partial class MainWindow : Window
{
public MainViewModel ViewModel { get; } = new MainViewModel();
public MainWindow()
{
this.InitializeComponent();
}
}
Create a simple MainViewModel with a collection of items to display:
public class MainViewModel
{
public ObservableCollection<Item> Items { get; set; }
public MainViewModel()
{
Items = new ObservableCollection<Item>
{
new Item { Name = "Item 1", Price = 10.0, Quantity = 1 },
new Item { Name = "Item 2", Price = 15.0, Quantity = 2 },
new Item { Name = "Item 3", Price = 20.0, Quantity = 3 },
// Add more items here
};
}
}
public class Item : INotifyPropertyChanged
{
private string _name;
private double _price;
private int _quantity;
public string Name
{
get => _name;
set
{
_name = value;
OnPropertyChanged(nameof(Name));
}
}
public double Price
{
get => _price;
set
{
_price = value;
OnPropertyChanged(nameof(Price));
}
}
public int Quantity
{
get => _quantity;
set
{
_quantity = value;
OnPropertyChanged(nameof(Quantity));
}
}
private void OnPropertyChanged(string propertyName)
{
PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));
}
public event PropertyChangedEventHandler PropertyChanged;
}
Build and run your application. You should see the TableView populated with the rows and cells from your ViewModel.
You can customize the appearance and behavior of the TableView by modifying its properties, templates, and styles. For example:
CornerButtonMode property to configure the corner button's behavior. You can select from:
None: No corner button.SelectAll: Displays a "Select All" button.Options: Displays an options menu.<tv:TableView x:Name="MyTableView"
ItemsSource="{x:Bind ViewModel.Items}"
AutoGenerateColumns="False"
xmlns:tv="using:WinUI.TableView">
<tv:TableView.Columns>
<tv:TableViewTextColumn Header="Name" Binding="{Binding Name}" />
<tv:TableViewNumberColumn Header="Price" Binding="{Binding Price}" />
<tv:TableViewTemplateColumn Header="Quantity">
<tv:TableViewTemplateColumn.CellTemplate>
<DataTemplate>
<TextBlock Text="{Binding Quantity}" />
</DataTemplate>
</tv:TableViewTemplateColumn.CellTemplate>
<tv:TableViewTemplateColumn.EditingTemplate>
<DataTemplate>
<NumberBox Value="{Binding Quantity, Mode=TwoWay}" />
</DataTemplate>
</tv:TableViewTemplateColumn.EditingTemplate>
</tv:TableViewTemplateColumn>
</tv:TableView.Columns>
</tv:TableView>
Contributions are welcome from the community! If you find any issues or have suggestions for improvements, please submit them through the GitHub issue tracker or consider making a pull request.
If this project saves you time or adds value to your work, please consider supporting its continued development.
Your sponsorship helps cover development time, testing, and future improvements.
👉 Become a supporter on Patreon
Every contribution makes a difference — thank you!
This project is licensed under the MIT License.