列表视图数据不会在 WPF 应用中刷新
本文关键字:WPF 应用 刷新 视图 数据 列表 | 更新日期: 2023-09-27 18:33:42
我正在尝试使用存储过程和实体框架将数据加载到 WPF 中的 ListView 中。当我第一次加载用户控件时,ListView 可以很好地加载数据。然后,我调用相同的代码来刷新数据,并且可以通过调试看到 ListItems 计数发生了变化,但前端屏幕上的数据不会更新。
XAML
<ListView Name="DocsListView" ItemsSource="{Binding}">
<ListView.View>
<GridView>
<GridViewColumn Header="Documents" DisplayMemberBinding="{Binding Documents}"/>
</GridView>
</ListView.View>
</ListView>
代码隐藏
public void LoadDocs()
{
Context _Context = new Context();
DocsListView.ItemsSource = null;
DocsListView.ItemsSource = _Context.SP_GetDocuments(1).ToList();
_Context = null;
}
有人可以帮我弄清楚我做错了什么吗?我使用的是VS2012,.Net 4.5和EF 5.0。
我不确定是什么导致了问题,通常我建议使用依赖属性!
但是您可以尝试像这样刷新列表视图:
ICollectionView view = CollectionViewSource.GetDefaultView(DocsListView.ItemsSource);
view.Refresh();
如果这将是一个更大的项目,我强烈建议看看MVVM DesignPattern!
WPF 和 MVVM 配合得很好。有一些不错的库,你可以使用,比如MVVMLight。
另外,您应该查看INotifyPropertyChanged Interface。
XAML 代码(不要忘记设置数据上下文)
<Window x:Class="WpfApplication1.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="MainWindow" Height="350" Width="525"
DataContext="{Binding RelativeSource={RelativeSource Self}}">
<Grid>
<ListView Name="DocsListView" ItemsSource="{Binding Data}">
<ListView.View>
<GridView>
<GridViewColumn Header="Documents" DisplayMemberBinding="{Binding Documents}"/>
</GridView>
</ListView.View>
</ListView>
</Grid>
</Window>
C# 代码隐藏(如果添加或删除项,可观察集合会自动刷新 UI):
public ObservableCollection<YourEntity> Data
{
get { return (ObservableCollection<YourEntity>)GetValue(DataProperty); }
set { SetValue(DataProperty, value); }
}
// Using a DependencyProperty as the backing store for Data. This enables animation, styling, binding, etc...
public static readonly DependencyProperty DataProperty =
DependencyProperty.Register("Data", typeof(ObservableCollection<YourEntity>), typeof(MainWindow), null);
public void LoadDocs()
{
Context _Context = new Context();
if(Data == null)
{
Data = new ObservableCollection<YourEntity>();
}
else
{
Data.Clear();
}
foreach(var doc in _Context.SP_GetDocuments(1).ToList())
{
Data.Add(doc);
}
_Context = null;
}