DevExpress WPF拥有120+个控件和库,将帮助您交付满足甚至超出企业需求的高性能业务应用程序。通过DevExpress WPF能创建有着强大互动功能的XAML基础应用程序,这些应用程序专注于当代客户的需求和构建未来新一代支持触摸的解决方案。 无论是Office办公软件的衍伸产品,还是以数据为中心的商业智能产品,都能通过DevExpress WPF控件来实现。
本文将演示如何将GridControl绑定到有限制的自定义服务(例如,不兼容的过滤器和排序),由于内容较多,我们将分为几篇文章来阐述,欢迎持续关注我们哟~
在上文中(点击这里回顾>>),我们为大家介绍了如何启用过搜索面板,本文将继续介绍如何考虑排序和过滤器限制,欢迎持续关注~
Step 5:考虑排序和过滤器限制
如果您已成功完成上述步骤,那么网格控件的用户界面将允许最终用户执行数据管理操作。然而Issues Service存在特定的排序和筛选限制:
- Hot 和Week只能通过标签进行筛选。
- 在按Votes 排序之后,您才能仅通过Votes进行筛选。
注意:在本教程中,使用Issues Service作为数据源的示例。
如果您发出的请求违反了上述限制规定,就会出现错误:
C#
cs
static void CheckRestrictions(IssueSortOrder sortOrder, IssueFilter filter) {
if(filter == null)
return;
if((sortOrder == IssueSortOrder.Hot || sortOrder == IssueSortOrder.Week)
&& (filter.CreatedFrom != null || filter.CreatedTo != null || filter.MaxVotes != null || filter.MinVotes != null))
throw new InvalidOperationException("Restrictions violation");
if((filter.MaxVotes != null || filter.MinVotes != null)
&& !(sortOrder == IssueSortOrder.VotesAscending || sortOrder == IssueSortOrder.VotesDescending))
throw new InvalidOperationException("Restrictions violation");
}
以下图片展示了如果按照Votes这一筛选条件进行筛选,但所选筛选条件与Hot排序顺序不匹配时会出现的错误:

若要避免出现此类错误消息,请让GridControl 控件忽略由数据服务所限制的操作,本文将详细介绍如何实现此操作。
考虑排序和筛选限制
- 创建一个函数,用于实现服务的限制条件,并判断排序和筛选操作是否兼容:
C#
cs
static bool IsValidFilter(string filterProperty, string sortProperty) {
if(filterProperty == "Tags")
return true;
if(sortProperty == "Hot" || sortProperty == "Week")
return false;
if(filterProperty == "Votes" && sortProperty != "Votes")
return false;
return true;
}
- 处理DataControlBaseFilterGroupSortChanging事件,来丢弃与排序不兼容的过滤条件:
C#
cs
void OnFilterGroupSortChanging(object sender, FilterGroupSortChangingEventArgs e) {
// ...
var sortProperty = e.SortInfo.SingleOrDefault()?.PropertyName;
var invalidFilters = e.SplitColumnFilters.Keys
.Where(key => !IsValidFilter(key, sortProperty))
.ToArray();
foreach(var invalidFilter in invalidFilters)
e.SplitColumnFilters.Remove(invalidFilter);
}
示例 1
如果您执行以下操作,则"按投票数筛选"的功能将被取消:
- 按票数排序
- 按票数筛选
- 按创建时间排序

这个实力表明,更改排序模式会清除不兼容的筛选条件。
示例 2
如果您执行以下操作,则"按投票数筛选"的功能将被取消:
- 按创建时间排序
- 按投票数筛选

在本示例中,通过"投票数"进行筛选并无意义(Issues Service只有在按照"投票数"进行排序后才能进行筛选操作),请按照下一步操作来禁止此类操作。
禁止终端用户使用违反Issues Service限制的过滤器:
XAML
XML
<dxg:GridColumn FieldName="Created" AllowColumnFiltering="{DXBinding '$dxu:DefaultBooleanExtension.ToDefaultBoolean(!@e(hotColumn).IsSorted and !@e(weekColumn).IsSorted)'}" />
<dxg:GridColumn FieldName="Votes" AllowColumnFiltering="{DXBinding '$dxu:DefaultBooleanExtension.ToDefaultBoolean(@Self.IsSorted)'}" />
下面的图片展示了结果:
