WPF MvvM DataGrid数据不刷新的原因

后台修改前台不刷新可能的原因:

1.前台页面没有写Binding

2.后台数据定义的字段没有get和set

3.数据容器没有使用ObservableCollection

4.字段内容修改时没有重置数据源

首先简单举例界面代码如下:

<DataGrid Name="DG" ItemsSource="{Binding}" AutoGenerateColumns="False">
<DataGrid.Columns>
<DataGridTextColumn Header="姓名" Binding="{Binding Name}" />
</DataGrid.Columns>
</DataGrid>

必须对DataGrid设置   ItemsSource="{Binding}" 

字段设置必须写  Binding="{Binding Name}" 

对应数据为:

 public class DataItem
 {
        public string Name { get; set; }
 }

字段名称必须和页面保持一致,字段必须是属性,包含get和set

定义成员变量:

 ObservableCollection<DataItem> m_data = new ObservableCollection<DataItem>(); 

关联前后台数据:

  DG.ItemsSource = m_data; 

ObservableCollection容器用法类似于List,这玩意可以在增加、删除(也就是Count发生变化)元素时发出通知。

所以我们在后台增加数据: DataItem cm = new DataItem(); cm.Name = "AA"; m_data.Add(cm);     界面会发生变化

在后台删除数据: m_data_data.RemoveAt(0);    界面也会发生变化

但是我们修改数据: m_data[0].Name = "MM";     此时界面并不会发生变化(因为Count没有发生变化。。。)

所以这个时候 DG.ItemsSource = null; DG.ItemsSource = m_data;  界面就可以变化了

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
WPF MVVM 中处理 DataGrid 数据有几个步骤: 1. 创建一个 ViewModel 类来管理 DataGrid数据。这个 ViewModel 类应该实现 INotifyPropertyChanged 接口,以便在数据改变时通知 View 更新。 2. 在 XAML 中创建 DataGrid 控件,并绑定到 ViewModel 的数据属性。可以使用 ItemsSource 属性将数据集合绑定到 DataGrid。 3. 在 ViewModel 中创建一个数据集合属性,用于存储 DataGrid数据。这个属性应该是一个 ObservableCollection<T> 类型,其中 T 是 DataGrid 中每一行的数据模型类。 4. 在 ViewModel 中,通过命令或其他方式获取要显示在 DataGrid 中的数据,并将其添加到数据集合属性中。 5. 可以使用数据绑定和转换器来设置 DataGrid 的列样式和格式。例如,可以使用 DataGridTextColumn 来显示文本数据,或者使用 DataGridTemplateColumn 来自定义列。 6. 在 ViewModel 中,可以处理 DataGrid 中的用户交互事件,例如选中行或编辑单元格。可以使用命令来处理这些事件,并在需要时更新数据集合属性。 7. 可以在 ViewModel 中添加一些数据处理逻辑,例如排序、过滤或分页。可以通过操作数据集合属性来实现这些功能,并通过绑定更新 DataGrid。 总的来说,WPF MVVM 中处理 DataGrid 数据需要创建一个 ViewModel 类来管理数据,并通过数据绑定将其与 DataGrid 控件关联起来。然后,在 ViewModel 中处理数据的增删改查操作,并使用命令和事件处理来实现用户交互。
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值