WPF的数据绑定机制允许界面元素和数据源自动同步,无需手动编写界面更新的逻辑,而MVVM模式则是WPF开发中最常用的架构模式,通过数据绑定实现视图、视图模型、模型的分离。下面我们从基础到进阶逐步讲解实现方式。

一、WPF基础数据绑定实现
WPF原生支持数据绑定,不需要依赖MVVM也可以实现简单的绑定效果,核心是通过Binding标记扩展指定数据源和绑定路径。
1.1 简单属性绑定示例
首先创建一个简单的数据模型,然后在XAML中绑定到界面元素:
// 数据模型类
public class UserInfo
{
public string Name { get; set; }
public int Age { get; set; }
}
在窗口的XAML中,我们将TextBox的Text属性绑定到UserInfo的Name属性:
<Window x:Class="WpfBindingDemo.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="MainWindow" Height="300" Width="400">
<StackPanel Margin="20">
<TextBlock Text="姓名:" />
<TextBox x:Name="NameTextBox" Text="{Binding Name, UpdateSourceTrigger=PropertyChanged}" Width="200" />
<TextBlock Text="年龄:" Margin="0,10,0,0" />
<TextBox Text="{Binding Age}" Width="200" />
</StackPanel>
</Window>
在窗口的后台代码中设置数据源:
public partial class MainWindow : Window
{
public MainWindow()
{
InitializeComponent();
// 设置数据上下文为UserInfo实例
this.DataContext = new UserInfo
{
Name = "张三",
Age = 25
};
}
}
运行后修改TextBox的内容,数据源的对应属性会同步更新,这就是最基础的单向/双向绑定效果。
二、MVVM模式下的数据绑定实现
MVVM模式要求视图(View)只负责界面展示,业务逻辑放在视图模型(ViewModel)中,两者通过数据绑定通信,需要实现属性变更通知和命令绑定。
2.1 实现INotifyPropertyChanged接口
要让数据源的属性变更后自动通知界面更新,需要让视图模型实现INotifyPropertyChanged接口,这是MVVM数据绑定的核心:
using System.ComponentModel;
using System.Runtime.CompilerServices;
public class MainViewModel : INotifyPropertyChanged
{
private string _userName;
private int _userAge;
// 属性变更事件,界面会监听这个事件更新绑定
public event PropertyChangedEventHandler PropertyChanged;
// 触发属性变更通知的方法
protected virtual void OnPropertyChanged([CallerMemberName] string propertyName = null)
{
PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));
}
// 封装的属性,修改时触发通知
public string UserName
{
get { return _userName; }
set
{
if (_userName != value)
{
_userName = value;
OnPropertyChanged();
}
}
}
public int UserAge
{
get { return _userAge; }
set
{
if (_userAge != value)
{
_userAge = value;
OnPropertyChanged();
}
}
}
}
2.2 视图绑定到视图模型
修改窗口的XAML,绑定到视图模型的属性,不需要再写后台代码设置数据源:
<Window x:Class="WpfBindingDemo.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="clr-namespace:WpfBindingDemo"
Title="MainWindow" Height="300" Width="400">
<Window.DataContext>
<!-- 直接设置窗口的数据上下文为视图模型实例 -->
<local:MainViewModel UserName="李四" UserAge="30" />
</Window.DataContext>
<StackPanel Margin="20">
<TextBlock Text="姓名:" />
<TextBox Text="{Binding UserName, UpdateSourceTrigger=PropertyChanged}" Width="200" />
<TextBlock Text="年龄:" Margin="0,10,0,0" />
<TextBox Text="{Binding UserAge}" Width="200" />
<Button Content="修改姓名" Command="{Binding ChangeNameCommand}" Margin="0,10,0,0" Width="200" />
</StackPanel>
</Window>
2.3 命令绑定实现
MVVM中按钮的点击事件通过命令绑定实现,避免直接在后台写事件处理逻辑。首先在视图模型中定义命令:
using System.Windows.Input;
public class RelayCommand : ICommand
{
private readonly Action _execute;
private readonly Func<bool> _canExecute;
public RelayCommand(Action execute, Func<bool> canExecute = null)
{
_execute = execute ?? throw new ArgumentNullException(nameof(execute));
_canExecute = canExecute;
}
// 判断命令是否可执行
public bool CanExecute(object parameter)
{
return _canExecute == null || _canExecute();
}
// 命令执行逻辑
public void Execute(object parameter)
{
_execute();
}
// 可执行状态变更通知,一般不需要手动调用
public event EventHandler CanExecuteChanged
{
add { CommandManager.RequerySuggested += value; }
remove { CommandManager.RequerySuggested -= value; }
}
}
然后在MainViewModel中添加命令属性和逻辑:
public class MainViewModel : INotifyPropertyChanged
{
// 之前的属性和代码省略...
private ICommand _changeNameCommand;
public ICommand ChangeNameCommand
{
get
{
if (_changeNameCommand == null)
{
_changeNameCommand = new RelayCommand(() =>
{
// 点击按钮后修改UserName,会自动通知界面更新
UserName = "王五";
}, () => !string.IsNullOrEmpty(UserName));
}
return _changeNameCommand;
}
}
}
三、绑定常用配置说明
在实际开发中,我们可以根据需求调整绑定的行为,常用的配置如下:
- Mode:绑定模式,可选OneWay(单向,数据源改界面更)、TwoWay(双向,互相更)、OneTime(仅初始化时绑定一次)、OneWayToSource(界面改数据源更)
- UpdateSourceTrigger:数据源更新触发时机,默认是LostFocus(控件失去焦点时更新),设置为PropertyChanged可以实时更新
- Converter:值转换器,当绑定数据类型不匹配时,可以通过实现
IValueConverter接口进行转换
通过以上步骤,就可以完整实现WPF的MVVM数据绑定,既保证了界面和业务逻辑的分离,又能实现高效的界面数据同步。
WPF数据绑定MVVMINotifyPropertyChanged修改时间:2026-06-29 21:33:49