0

我有一个包含大约 30'000 个条目的数据源(列表类型)。

public class LocationItem
{
    public string Name { get; set; };
    public double Latitude { get; set; };
    public double Longitude { get; set; };
    public double Height { get; set; };
}

将此源绑定到我的 AutoCompleteBox 后,每个输入的字母需要大约 1-3 秒来过滤。过滤器类型为“自定义”。我的过滤方法不是瓶颈——我使用“秒表”类和性能分析器检查了这一点。过滤不在第四个字符之前开始。

更快一点的唯一替代方法是使用 TextChanged 事件而不是实现的过滤器行为。在 TextChanged 事件中,我过滤了原始数据源 (Linq),并且仅将过滤后的子集绑定到 AutoCompleteBox。

有没有其他方法可以提高性能?或者将数据源(具有数千个条目)绑定到具有过滤功能的 AutoCompleteBox 的最佳实践是什么?

亲切的问候,丹尼

4

2 回答 2

0

如果您执行异步过滤会更好。
这是在 Silveright 中使用 AutoCompleteBox 的教程http://www.silverlightshow.net/items/Using-the-AutoCompleteBox.aspx。有一个异步过滤的例子。该示例使用 Web 服务,但您可以将其替换为本地服务,该服务从您已经加载的文件或集合中加载数据。

于 2012-02-18T06:39:53.187 回答
0
void SetData()
{
    ...
    autoCompleteBox = Data.GetRange(0, 30);
    ...
}

void autoCompleteBox_DropDownOpened(object sender, RoutedPropertyChangedEventArgs<bool> e)
{
    autoCompleteBox.ItemsSource = Data;
}
于 2012-03-29T08:08:20.270 回答