半岛外围网上直营

DevExpress WPF中文教程:Data Grid - 如何使用虚拟源?(三)

翻译|使用教程|编辑:龚雪|2025-10-22 10:45:59.963|阅读 6 次

概述:本文主要介绍如何在MVVM应用程序中使用虚拟源,欢迎下载最新版组件体验!

# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>

相关链接:

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

本文将为大家一步一步演示如何在一个MVVM应用程序中使用虚拟源。

DevExpress WPF中文教程图集

注意:本教程使用作为示例数据源,使用作为虚拟数据源。

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

DevExpress技术交流群12:1028386091      欢迎一起进群讨论

Step 3: 启用过滤器操作

您可以允许用户在GridControl中过滤行,完成以下步骤:

1. 在虚拟源中实现过滤操作。

2. 在GridControl中启用过滤器操作。

DevExpress WPF中文教程图集
过滤器类型

可以获取行:

  • 具有指定的优先级。
  • 在一段时间内(在CreatedFrom和CreatedTo之间)。
  • 获得最多的票数。

C#

public class IssueFilter {
public Priority? Priority { get; private set; }
public DateTime? CreatedFrom { get; private set; }
public DateTime? CreatedTo { get; private set; }
public int? MinVotes { get; private set; }
}

下面的代码片段获取不带过滤条件的行:

C#

[Command]
public void FetchIssues(FetchRowsAsyncArgs args) {
args.Result = GetIssuesAsync(args);
}
async Task<FetchRowsResult> GetIssuesAsync(FetchRowsAsyncArgs args) {
var take = args.Take ?? 30;
var issues = await IssuesService.GetIssuesAsync(
skip: args.Skip,
take: take,
sortOrder: GetIssueSortOrder(args.SortOrder),
filter: null
);

return new FetchRowsResult(issues, hasMoreRows: issues.Length == take);
}
实现细节
创建过滤器转换器

1. 创建一个过滤器转换器。

2. 获取GridControl过滤器。

3. 解析过滤器并返回一个IssueFilter(模型中使用的类型),绑定到的命令在GridControl获取行时使用过滤器。

C#

public class IssueFilterConverter : MarkupExtension, IValueConverter {
object IValueConverter.Convert(object filter, Type targetType, object parameter, CultureInfo culture) {
return ((CriteriaOperator)filter).Match(
binary: (propertyName, value, type) => {
if (propertyName == "Votes" && type == BinaryOperatorType.GreaterOrEqual)
return new IssueFilter(minVotes: (int)value);
if (propertyName == "Priority" && type == BinaryOperatorType.Equal)
return new IssueFilter(priority: (Priority)value);
if (propertyName == "Created") {
if (type == BinaryOperatorType.GreaterOrEqual)
return new IssueFilter(createdFrom: (DateTime)value);
if (type == BinaryOperatorType.Less)
return new IssueFilter(createdTo: (DateTime)value);
}
throw new InvalidOperationException();
},
and: filters => {
return new IssueFilter(
createdFrom: filters.Select(x => x.CreatedFrom).SingleOrDefault(x => x != null),
createdTo: filters.Select(x => x.CreatedTo).SingleOrDefault(x => x != null),
minVotes: filters.Select(x => x.MinVotes).SingleOrDefault(x => x != null),
priority: filters.Select(x => x.Priority).SingleOrDefault(x => x != null)
);
},
@null: default(IssueFilter)
);
}
object IValueConverter.ConvertBack(object value, Type targetType, object parameter, CultureInfo culture) {
throw new NotImplementedException();
}
public override object ProvideValue(IServiceProvider serviceProvider) => this;
}

提示

上面的代码示例使用了FilterCriteriaMatchHelper.Match方法,该方法允许您解析GridControl创建的过滤条件。

FilterCriteriaMatchHelper是来自DevExpress.Xpf.Grid.v25.1.Extensions.dll库的扩展。

4. 将过滤器转化器分配给属性,View中指定的过滤器转换器允许您避免在ViewModel中引用DevExpressData命名空间。

XML

<dxg:GridControl CriteriaConverter="{local:IssueFilterConverter}"/>

如果您可以在ViewModel中引用DevExpress.Data命名空间,则创建一个方法来解析ViewModel中的GridControl过滤器。

5. 当您指定属性时,属性返回Object类型的过滤器,可以将此过滤器转换为过滤器转换器(本教程中的IssueFilter)返回的类型。

C#

[Command]
public void FetchIssues(FetchRowsAsyncArgs args) {
args.Result = GetIssuesAsync(args);
}
async Task<FetchRowsResult> GetIssuesAsync(FetchRowsAsyncArgs args) {
var take = Math.Min(args.Take ?? 30, 100);
var issues = await IssuesService.GetIssuesAsync(
skip: args.Skip,
take: take,
sortOrder: GetIssueSortOrder(args.SortOrder),
filter: (IssueFilter)args.Filter
);

return new FetchRowsResult(issues, hasMoreRows: issues.Length == take);
}
获取优先级

获取优先级列表,并在Priority列下拉过滤器中显示它们:

DevExpress WPF中文教程图集

1. 创建GetUniqueValues命令。

2. 使用属性获取GridControl为其收集唯一值的字段名。

3. 获取唯一值列表并将其分配给Result属性。

4. 将命令绑定到。

C#

[Command]
public void GetUniqueValues(GetUniqueValuesAsyncArgs args) {
if(args.PropertyName == "Priority") {
var values = Enum.GetValues(typeof(Priority)).Cast<object>().ToArray();
args.Result = Task.FromResult(values);
} else {
throw new InvalidOperationException();
}
}

XML

<dxg:GridControl CriteriaConverter="{local:IssueFilterConverter}">
<dxg:GridControl.ItemsSource>
<dx:InfiniteAsyncSource ElementType="{x:Type local:IssueData}"
FetchRowsCommand="{Binding FetchIssuesCommand}"
GetUniqueValuesCommand="{Binding GetUniqueValuesCommand}"/>
</dxg:GridControl.ItemsSource>
<!-- ... -->
</dxg:GridControl>

如果服务或数据库包含获取唯一值的方法,请在GetUniqueValues命令中使用该方法。

启用优先列过滤

允许用户通过Priority列过滤GridControl行,如下所示:

1. 将属性设置为Equals,来允许用户显示具有指定优先级的行。

2. 将ColumnBaseFilterPopupMode属性设置为List,来启用允许用户一次选择一个项的下拉过滤器。

XML

<dxg:GridColumn FieldName="Priority"
AllowedBinaryFilters="Equals"
FilterPopupMode="List"/>
DevExpress WPF中文教程图集
启用Votes列过滤

允许用户按Votes列过滤GridControl行,如下所示:

1. 将属性设置为GreaterOrEqual,来以允许用户显示投票值大于或等于输入值的行。

2. 将属性设置为Excel,来启用允许用户创建GreaterOrEqual标准的下拉过滤器。

XML

<dxg:GridColumn FieldName="Votes"
AllowedBinaryFilters="GreaterOrEqual"
FilterPopupMode="Excel"/>
DevExpress WPF中文教程图集
启用已创建Date列过滤

允许用户按Created Date(创建日期)列过滤GridControl行,如下所示:

1. 将属性设置为SingleDateRange,来允许用户按单个日期或日期范围过滤行。

2. 将属性设置为DateSmart,来启用允许用户指定日期的日历。

XML

<dxg:GridColumn FieldName="Created"
AllowedDateTimeFilters="SingleDateRange"
FilterPopupMode="DateSmart"/>
DevExpress WPF中文教程图集

更多产品资讯及授权,欢迎来电咨询:023-68661681


关于慧都科技

慧都是⼀家⾏业数字化解决⽅案公司,专注于软件、⽯油与⼯业领域,以深⼊的业务理解和⾏业经验,帮助企业实现智能化转型与持续竞争优势。

慧都是DevExpress的中国区的合作伙伴,DevExpress作为用户界面领域的优秀产品,帮助企业高效构建权限管理、数据可视化(如网格/图表/仪表盘)、跨平台系统(WinForms/ASP.NET/.NET MAUI)及行业定制解决方案,加速开发并强化交互体验。


标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@ke049m.cn

文章转载自:慧都网

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP
利记足球官网(官方)网站/网页版登录入口/手机版登录入口-最新版(已更新) 真人boyu·博鱼滚球网(官方)网站/网页版登录入口/手机版登录入口-最新版(已更新) 最大网上PM娱乐城盘口(官方)网站/网页版登录入口/手机版登录入口-最新版(已更新) 正规雷火竞技官方买球(官方)网站/网页版登录入口/手机版登录入口-最新版(已更新) 雷火竞技权威十大网(官方)网站/网页版登录入口/手机版登录入口-最新版(已更新) boyu·博鱼信誉足球官网(官方)网站/网页版登录入口/手机版登录入口-最新版(已更新) 权威188BET足球网(官方)网站/网页版登录入口/手机版登录入口-最新版(已更新) 正规188BET足球大全(官方)网站/网页版登录入口/手机版登录入口-最新版(已更新)