WPF怎么实现数据绑定 WPF MVVM数据绑定方法

WPF数据绑定依赖DependencyProperty和INotifyPropertyChanged,ViewModel需实现该接口并触发PropertyChanged事件,View通过DataContext关联ViewModel,Binding路径须为public属性且区分大小写,集合应使用ObservableCollection。

WPF 中的数据绑定核心是 依赖属性(DependencyProperty)INotifyPropertyChanged 接口,MVVM 模式下,View 绑定 ViewModel 的属性,靠的是这两者配合实现自动更新。

ViewModel 必须实现 INotifyPropertyChanged

这是让 UI 感知数据变化的关键。不实现它,修改属性值后界面不会刷新。

  • 在 ViewModel 类中继承 INotifyPropertyChanged 接口
  • 定义一个 OnPropertyChanged 方法,内部调用 PropertyChanged?.Invoke(...)
  • 每个可绑定的属性 setter 中都要调用该方法,传入属性名(推荐用 [CallerMemberName] 避免硬编码字符串)

示例:

public class MainViewModel : INotifyPropertyChanged
{
private string _title = "默认标题";
public string Title
{
get => _title;
set
{
if (_title != value)
{
_title = value;
OnPropertyChanged(); // 自动获取属性名
}
}
}

public event PropertyChangedEventHandler PropertyChanged;
protected virtual void OnPropertyChanged([CallerMemberName] string propertyName = null) =>
PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));
}

View 中通过 DataContext 关联 ViewModel

绑定生效的前提是 View 知道该找谁要数据。通常在窗口或控件初始化时设置 DataContext

  • 代码中设置:this.DataContext = new MainViewModel();
  • XAML 中用 DataContext 属性直接实例化(适合简单场景):
  • 更推荐用资源+静态资源方式,便于设计时支持和复用

XAML 中写 Binding 表达式

绑定语法灵活,常见写法有:

  • Text="{Binding Title}" —— 默认 Mode=OneWay,绑定到 ViewModel 的 Title 属性
  • Text="{Binding Path=Title, Mode=TwoWay}" —— 显式指定双向绑定(如 TextBox 输入后同步回 ViewModel)
  • ItemsSource="{Binding Products}" —— 绑定集合,配合 ListBox 或 DataGrid 使用
  • Command="{Binding SaveCommand}" —— 绑定 ICommand 实现(如 RelayCommand),响应按钮点击等操作

注意:Binding 路径区分大小写,且只支持 public 属性,不支持字段。

集合绑定要选对类型

如果绑定的是列表(比如显示商品列表),ViewModel 中的集合必须是 ObservableCollection 或其它能触发通知的集合类型。

  • List 不会通知新增/删除,改了也不会刷新 UI
  • ObservableCollection 在 Add/Remove/Clear 时自动触发 CollectionChanged 事件
  • 若需排序或过滤,可用 CollectionViewSource 包装,支持分组、筛选、当前项跟踪

基本上就这些。WPF 数据绑定不复杂但容易忽略细节,关键是 ViewModel 可通知、View 有上下文、Binding 写对路径——三者齐备,自动联动就跑起来了。