如何定义搜索面板的过滤器?DevExpress WPF超easy

如何定义搜索面板的过滤器?DevExpress WPF超easyDevExpress广泛应用于ECM企业内容管理、 成本管控、进程监督、生产调度,在企业/政务信息化管理中占据一席重要之地。

欢迎大家来到IT世界,在知识的湖畔探索吧!

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

DevExpress WPF Controls v19.2下载:https://www.devexpresscn.com/download.html

问题:

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

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自定义函数。

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 v19.2全新发布,最新动态请持续关注DevExpress中文网!

https://www.devexpresscn.com/

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

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://itzsg.com/34169.html

(0)

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们YX

mu99908888

在线咨询: 微信交谈

邮件:itzsgw@126.com

工作时间:时刻准备着!

关注微信