C# 如何在 WPF 中进行数据绑定_C# WPF 数据绑定完整指南

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

C# 如何在 WPF 中进行数据绑定_C# WPF 数据绑定完整指南

WPF 的数据绑定是构建动态、响应式用户界面的核心机制。它允许 UI 元素自动反映数据的变化,无需手动更新控件。要实现高效的数据绑定,需理解其基本语法、绑定模式、数据源类型以及如何支持属性变更通知。

1. 数据绑定基础:Binding 语法与模式

在 XAML 中,使用 Binding 标记扩展将控件属性绑定到数据源的属性。最常见的是绑定 TextBlock.TextTextBox.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 “`

也可显式指定 SourceElementName

“`xml “`

3. 实现属性变更通知:INotifyPropertyChanged

若希望 UI 在属性更改后自动刷新,数据类必须实现 INotifyPropertyChanged 接口。

实现方式:

C# 如何在 WPF 中进行数据绑定_C# WPF 数据绑定完整指南

即构数智人

即构数智人是由即构科技推出的ai虚拟数字人视频创作平台,支持数字人形象定制、短视频创作、数字人直播等。

C# 如何在 WPF 中进行数据绑定_C# WPF 数据绑定完整指南36

查看详情 C# 如何在 WPF 中进行数据绑定_C# WPF 数据绑定完整指南

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 中使用 ItemsControlListBox 等展示:

“`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 数据绑定场景。

暂无评论

发送评论 编辑评论


				
上一篇
下一篇
text=ZqhQzanResources