DevExpress WPF中文教程:Data Grid - 如何绑定到有限制的自定义服务(一)?

DevExpress WPF拥有120+个控件和库,将帮助您交付满足甚至超出企业需求的高性能业务应用程序。通过DevExpress WPF能创建有着强大互动功能的XAML基础应用程序,这些应用程序专注于当代客户的需求和构建未来新一代支持触摸的解决方案。 无论是Office办公软件的衍伸产品,还是以数据为中心的商业智能产品,都能通过DevExpress WPF控件来实现。

本文将演示如何将GridControl绑定到有限制的自定义服务(例如,不兼容的过滤器和排序),由于内容较多,我们将分为几篇文章来阐述,欢迎持续关注我们哟~

获取DevExpress WPF v25.1正式版下载

Step 1:获取数据并启用滚动

在此步骤中,您将创建一个虚拟源,从服务中获取行,并在GridControl中启用滚动。

注意 :在本教程中,使用Issues Service作为数据源的示例。

获取数据和启用滚动
  1. 添加一个GridControl,列对应于Issues Service的IssueData到您的项目窗口:

XAML

XML 复制代码
<dxg:GridControl x:Name="grid" >
<dxg:GridControl.Columns>
<dxg:GridColumn FieldName="Subject" />
<dxg:GridColumn FieldName="User" />
<dxg:GridColumn FieldName="Created" />
<dxg:GridColumn FieldName="Votes" />
<dxg:GridColumn FieldName="Tags" />
</dxg:GridControl.Columns>
</dxg:GridControl>

注意GridControl不能显示Tags 列的值,因为IssueData.Tags属性的类型是一个字符串数组。

  1. 初始化虚拟源:

C#

cs 复制代码
public MainWindow() {
InitializeComponent();
var source = new InfiniteAsyncSource() {
CustomProperties = GetCustomProperties()
};
}
static DynamicPropertyDescriptor CreateTagsProperty() {
return new DynamicPropertyDescriptor(
name: "Tags",
propertyType: typeof(string),
getValue: x => string.Join(", ", ((IssueData)x).Tags));
}
static PropertyDescriptorCollection GetCustomProperties() {
var customProperties = TypeDescriptor.GetProperties(typeof(IssueData))
.Cast<PropertyDescriptor>()
.Where(x => x.Name != "Tags")
.Concat(new[] {
CreateTagsProperty()
})
.ToArray();
return new PropertyDescriptorCollection(customProperties);
}
  1. 处理虚拟源:

C#

cs 复制代码
public MainWindow() {
// ...
Unloaded += (o, e) => {
source.Dispose();
};
}
  1. 从数据源获取行:

C#

cs 复制代码
public MainWindow() {
// ...
source.FetchRows += (o, e) => {
e.Result = FetchRowsAsync(e);
};
}
static async Task<FetchRowsResult> FetchRowsAsync(FetchRowsAsyncEventArgs e) {
IssueSortOrder sortOrder = GetIssueSortOrder(e);
IssueFilter filter = MakeIssueFilter(e.Filter);
const int pageSize = 30;
var issues = await IssuesService.GetIssuesAsync(
page: e.Skip / pageSize,
pageSize: pageSize,
sortOrder: sortOrder,
filter: filter);
return new FetchRowsResult(issues, hasMoreRows: issues.Length == pageSize);
}
static IssueSortOrder GetIssueSortOrder(FetchRowsAsyncEventArgs e) {
return IssueSortOrder.Default;
}
static IssueFilter MakeIssueFilter(CriteriaOperator filter) {
return null;
}

通过将生成的虚拟源实例赋值给DataControlBase.ItemsSource属性,将GridControl绑定到虚拟源:

C#

cs 复制代码
public MainWindow() {
// ...
grid.ItemsSource = source;
}
相关推荐
for_ever_love__3 小时前
UI学习:UICollectionView瀑布流
学习·ui·ios·objective-c·cocoa
xiaobai1786 小时前
pytest+playwright实现UI自动化(4)-上夹具fixture
ui·自动化·pytest·playwright
为何创造硅基生物8 小时前
LVGL 妙用 LV_OBJ_FLAG_FLOATING
ui
ANnianStriver10 小时前
PetLumina 04 — 管理后台 UI 全面升级
java·ui·ai编程
123的故事11 小时前
工具分享(2)-NSmartProxy内网穿透工具。
c#·.net·nsmartproxy
ANnianStriver11 小时前
PetLumina 05 — App 端 UI 效果应用
java·ui·ai编程
小小龙学IT11 小时前
Midscene.js:AI驱动的跨平台UI自动化革命
javascript·人工智能·ui
SEO-狼术12 小时前
Bring Agentic AI to RAD Studio
.net
Wenzar_13 小时前
Playwright 实战:高可信 UI 回归验证流水线
java·ui
足球中国14 小时前
.net winform 仿excel控件 开源地址 https://github.com/yufb12/dataexcel_winform
.net