开发者论坛

 找回密码
 注册 (请使用非IE浏览器)
查看: 6366|回复: 0

[DevExpress WPF使用教程]为Search Panel使用自定义过滤器

[复制链接]

0

精华

8

贡献

1768

赞扬

特约版主

帖子
583
软币
4524
在线时间
275 小时
注册时间
2019-2-21
发表于 2019-12-10 10:39:29 | 显示全部楼层 |阅读模式

DevExpress广泛应用于ECM企业内容管理、 成本管控、进程监督、生产调度,在企业/政务信息化管理中占据一席重要之地。通过DevExpress WPF Controls,您能创建有着强大互动功能的XAML基础应用程序,这些应用程序专注于当代客户的需求和构建未来新一代支持触摸的解决方案。 无论是Office办公软件的衍伸产品,还是以数据为中心的商业智能产品,都能通过该控件来实现。

DevExpress WPF Controls v19.2下载

问题:

项目中实现了customRowFilter(下面提供的代码),以便在用户搜索网格时忽略重音和大小写。目前存在的问题是,如果用户使用filter editor应用于列表,然后使用绑定到TableView.SearchString的搜索框。如何在FilterString和SearchString之间使用AND,现在似乎是OR。如何在这两个条件之间实现使用AND而不是OR?

[C#] 纯文本查看 复制代码
private List<GridColumn> _searchableColumns; 
private void OnCustomRowFilter(object sender, RowFilterEventArgs e) 
{ 
if (string.IsNullOrEmpty(View.SearchString) || e.Handled) 
return; 

if (_searchableColumns == null) 
{ 
_searchableColumns = new List<GridColumn>(); 
foreach (var c in Columns) 
{ 
if (c.FieldType == typeof(bool) || !c.AllowAutoFilter) 
continue; 

_searchableColumns.Add(c); 
} 
} 

var filter = RemoveDiacriticsCustom(View.SearchString).ToLower(); 
e.Visible = false; 
for (var i = 0; i < _searchableColumns.Count; i++) 
{ 
var processedString = RemoveDiacriticsCustom(GetCellDisplayTextByListIndex(e.ListSourceRowIndex, _searchableColumns[i])).ToLower(); 
if (processedString.Contains(filter)) 
{ 
e.Visible = true; 
break; 
} 
} 

e.Handled = true; 
} 

private static string RemoveDiacriticsCustom(string text) 
{ 
return string.Concat(text.Normalize(NormalizationForm.FormD).Where(ch => CharUnicodeInfo.GetUnicodeCategory(ch) != UnicodeCategory.NonSpacingMark)).Normalize(NormalizationForm.FormC); 
}

分析了DevExpress Searching/Filtering pipeline,发现可以修改以下方法实现搜索和忽略重音。在不修改DevExpress代码的情况下,有一种方法可以实现使用以下修改后代码的earchStringToFilterCriteria自定义函数。

[C#] 纯文本查看 复制代码
static bool? FnContainsCaseInsensitive(string str1, string str2) 
{ 
if(str1 == null || str2 == null) 
return null; 

//return 
//	str1.IndexOf(str2, StringComparison.InvariantCultureIgnoreCase) >= 0 || 
//	str1.IndexOfInvariantCultureIgnoreCase(str2) >= 0; 

var compareInfo = CultureInfo.InvariantCulture.CompareInfo; 
return compareInfo.IndexOf(str1, str2, CompareOptions.IgnoreCase | CompareOptions.IgnoreNonSpace) > -1; 
}

解决方案:

CustomRowFilter旨在覆盖默认过滤的结果,因此需要考虑FilterString属性值,或者使用其他事件。

建议考虑改用SearchStringToFilterCriteria事件,可以在其中指定如何将搜索字符串转换为过滤条件。例如创建一个自定义函数标准运算符,该运算符将删除变音符号并在SearchStringToFilterCriteria事件处理程序中使用它。

DevExpress中文网官网QQ群:540330292      欢迎一起进群讨论


回复

使用道具 举报

Archiver|手机版|小黑屋|开发者网 ( 苏ICP备08004430号-2 )
版权所有:南京韵文教育信息咨询有限公司

GMT+8, 2024-4-20 03:33

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表