我实现了一个简单的搜索功能,它根据搜索查询突出显示DataGrid中的一行。它的要点如下所示:
public bool scrollToSearch(string query) {
dataGrid.SelectedItems.Clear();
for (; searchIndex < registrants.Count; searchIndex++) {
foreach (string field in registrants[searchIndex]) {
if (field.ToLower().Contains(query)) {
dataGrid.SelectedItem = registrants[searchIndex];
dataGrid.ScrollIntoView(registrants[searchIndex]);
searchIndex++;
return true;
}
}
}
}
它在列表中搜索匹配项,然后突出显示(选择)该行并将其滚动到视图中。问题是,当DataGrid被排序时,搜索将突出显示一个看似随机的行而不是第一个结果,因为它正在搜索原始的未排序列表。我有没有办法在排序列表中搜索它?
答案 0 :(得分:1)
我同意Anurag的观点,即ListCollectionView是正确的方法。有关ListCollectionView的文档,请See here。 ListCollectionView在源和显示之间创建另一个层,用于处理排序,过滤和分组。将DataGrid绑定到ListCollectionView并使用SetCurrent()
指定所选项目。
答案 1 :(得分:0)
首先这样做....
var view = CollectionViewSource.GetDefaultView(registrants);
然后在代码中使用view
代替registrants
。