gpt4 book ai didi

WPF 数据绑定(bind)数据网格过滤/搜索

转载 作者:搜寻专家 更新时间:2023-10-30 21:54:21 26 4
gpt4 key购买 nike

我有一个 WPF 应用程序,它使用(当前)本地数据库作为绑定(bind)源。使用 Visual Studio 2010 工具,我有一个 LINQ-SQL 模型,它充当大多数表单的数据上下文。

我拥有的是一个带有文本框和数据网格的用户控件。数据网格 ItemSource 是根据 UserControl.Loaded 事件与表设置的。 TextBox 分配了一个事件,以便在文本更改时对数据库执行查询,并且 ItemSource 在数据网格上更新。

问题在于查询数据库所花费的时间。当我为每次搜索重新分配 DataGrid 项目源时。

  1. 我是否应该在 UserControl 加载时加载所有记录 - 有没有一种方法可以在 BackgroundWorker 或类似程序中异步加载记录?

  2. 我是否需要在每次搜索后重新分配 DataGrid ItemsSource,或者它们是一种更有效的数据过滤方式吗?

谢谢。利亚姆

<UserControl x:Class="Tracker.DocumentsView"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
mc:Ignorable="d"
d:DesignHeight="300" d:DesignWidth="300">
<Grid>
<DataGrid AutoGenerateColumns="False" Margin="12,34,12,50" Name="dataGrid1">
<DataGrid.Columns>
<DataGridTextColumn Binding="{Binding Path=ID}" Header="ID" />
<DataGridTextColumn Binding="{Binding Path=Reference}" Header="Reference" />
<DataGridTextColumn Binding="{Binding Path=Subject}" Header="Subject" />
</DataGrid.Columns>
</DataGrid>

<TextBox HorizontalAlignment="Left" Margin="64,8,0,0" Name="txtSearchBox" VerticalAlignment="Top" Width="224" TextChanged="txtSearchBox_TextChanged" />
<TextBlock Text="Search" HorizontalAlignment="Left" Margin="11,12,0,0" Name="label1" VerticalAlignment="Top" Height="23" />
</Grid>
</UserControl>

代码:

using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;

using Tracker.Model;

namespace Tracker
{
/// <summary>
/// Interaction logic for DocumentsView.xaml
/// </summary>
public partial class DocumentsView : UserControl
{
private TrackerDataContext db;

public DocumentsView()
{
InitializeComponent();
this.Loaded += new RoutedEventHandler(DocumentsView_Loaded);
}

void DocumentsView_Loaded(object sender, RoutedEventArgs e)
{
db = new TrackerDataContext();
dataGrid1.ItemsSource = db.Documents;
}

private void txtSearchBox_TextChanged(object sender, TextChangedEventArgs e)
{
TextBox textbox = sender as TextBox;
if (textbox != null)
{
string searchstr = textbox.Text;
if (!string.IsNullOrEmpty(searchstr))
{
var filtered = from document in db.Documents
where document.Subject.Contains(searchstr)
|| document.Reference.Contains(searchstr)
select document;

dataGrid1.ItemsSource = filtered;
}
else
{
dataGrid1.ItemsSource = db.Documents;
}
}
}
}
}

最佳答案

我认为你应该在开始时从数据库中加载所有记录然后在 ItemsSource 上使用 ICollectionView.Filter。这样您就不必进行数据库事务

你应该写这样的东西

    private void txtSearchBox_TextChanged(object sender, TextChangedEventArgs e)
{
TextBox textbox = sender as TextBox;
if (textbox != null)
{
_searchstr = textbox.Text;
if (!string.IsNullOrEmpty(_searchstr))
{
ICollectionView view = CollectionViewSource.GetDefaultView(ItemsSource);
view.Filter = new Predicate<object>(filter);
}
}
}

private bool filter(object item)
{
if(item.Subject.Contains(_searchstr) || item.Reference.Contains(searchstr))
{
return true;
}
return false;
}

希望对您有所帮助,尼达尔。

关于WPF 数据绑定(bind)数据网格过滤/搜索,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3264850/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com