wpf数据绑定通过Binding实现ui与数据的自动同步,依赖DataContext作为数据源,支持OneWay、TwoWay等模式;为响应属性变化,数据类需实现INotifyPropertyChanged接口;集合绑定推荐使用ObservableCollection以确保动态更新;通过IValueConverter可实现值的类型转换,如布尔值转Visibility,从而构建高效、响应式的用户界面。

WPF 的数据绑定是构建动态、响应式用户界面的核心机制。它允许 UI 元素自动反映数据的变化,无需手动更新控件。要实现高效的数据绑定,需理解其基本语法、绑定模式、数据源类型以及如何支持属性变更通知。
1. 数据绑定基础:Binding 语法与模式
在 XAML 中,使用 Binding 标记扩展将控件属性绑定到数据源的属性。最常见的是绑定 TextBlock.Text 或 TextBox.Text 到某个对象的属性。
示例: “`xml
Binding 支持多种 Mode 模式:
- OneWay:数据源变化时更新 UI(适用于只读显示)
- TwoWay:UI 和数据源双向同步(常用于表单输入)
- OneTime:仅在初始化时绑定一次
- OneWayToSource:从 UI 更新数据源(较少用)
默认情况下,Text 属性为 TwoWay,而 IsEnabled 等为 OneWay。
2. 设置数据源:DataContext 与 Source
WPF 绑定依赖于 DataContext,它是元素继承的数据上下文。通常在窗口或用户控件中设置。
代码示例(C#):
public class Person { public string Name { get; set; } public int Age { get; set; } } // 在窗口构造函数中设置 this.DataContext = new Person { Name = "张三", Age = 25 };
XAML 中直接绑定:
“`xml
也可显式指定 Source 或 ElementName:
“`xml
3. 实现属性变更通知:INotifyPropertyChanged
若希望 UI 在属性更改后自动刷新,数据类必须实现 INotifyPropertyChanged 接口。
实现方式:
using System.ComponentModel; using System.Runtime.CompilerServices; public class Person : INotifyPropertyChanged { private string name; public string Name { get => name; set { if (name != value) { name = value; OnPropertyChanged(); } } } public event PropertyChangedEventHandler PropertyChanged; protected void OnPropertyChanged([CallerMemberName] string name = null) { PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(name)); } }
这样,当修改 Name 时,所有绑定该属性的控件会自动更新。
4. 集合绑定与 ObservableCollection
绑定列表数据时,推荐使用 ObservableCollection<T>,它会在添加、删除项时自动通知 UI 更新。
示例:
public class MainwindowViewModel { public ObservableCollection<Person> People { get; set; } public MainWindowViewModel() { People = new ObservableCollection<Person> { new Person { Name = "李四", Age = 30 }, new Person { Name = "王五", Age = 28 } }; } }
XAML 中使用 ItemsControl、ListBox 等展示:
“`xml
若使用普通 List,集合变动不会触发 UI 更新。
5. 使用 Converter 进行值转换
当绑定的数据类型与 UI 显示不匹配时,可用 IValueConverter 转换值。
示例:布尔值转可见性
[ValueConversion(typeof(bool), typeof(Visibility))] public class BooleanToVisibilityConverter : IValueConverter { public object Convert(object value, Type targetType, object parameter, CultureInfo culture) { if (value is bool boolValue) return boolValue ? Visibility.Visible : Visibility.Collapsed; return Visibility.Collapsed; } public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture) { return value is Visibility visibility && visibility == Visibility.Visible; } }
XAML 中使用:
“`xml
<TextBlock Text=”已启用” Visibility=”{Binding IsActive, Converter={StaticResource BoolToVis}}”/>
基本上就这些。掌握 DataContext、INotifyPropertyChanged、ObservableCollection 和 Converter,就能应对大多数 WPF 数据绑定场景。


