c# - 将控件绑定(bind)到对象是否算作订阅?

标签 c# wpf events mvvm data-binding

所以我目前正在使用 MVVM 中的数据绑定(bind)。
所以我的类(class)来自INotifyPropertyChanged我正在将我的控件绑定(bind)到我类(class)中的属性。
通常在创建事件时,您会使用类似 += myMethod 的方法显式订阅它。但是,当我这样做时,我看不到 +=但它仍然有效。

我的问题是..
我的控件如何订阅 PropertyChanged事件
每当我将控件绑定(bind)到属性时,我的控件是否会隐式订阅该事件?
public event PropertyChangedEventHandler PropertyChanged;
主视图模型

class MasterViewModel
    {
        public Username Username { get; } = new Username();
    }

XAML
<TextBox Name="tbUsername" HorizontalAlignment="Left" Height="23" Margin="381,132,0,0" TextWrapping="Wrap" Text="{Binding Username.TheUsername}" VerticalAlignment="Top" Width="120"/>

类(class)
class Username : INotifyPropertyChanged
    {
        public event PropertyChangedEventHandler PropertyChanged;

        public Username()
        {
            TheUsername = "Hello World!";
        }

        private string _username;

        public string TheUsername
        {
            get { return _username; }
            set
            {
                _username = value;
                OnPropertyChanged("TheUsername");
            }
        }



        [NotifyPropertyChangedInvocator]
        protected virtual void OnPropertyChanged([CallerMemberName] string propertyName = null)
        {
            PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));
        }
    }

最佳答案

框架 (WPF) 会为您处理订阅。它应用了 MSDN 中提到的弱事件模式:https://docs.microsoft.com/en-us/dotnet/framework/wpf/advanced/weak-event-patterns

简而言之,框架检查绑定(bind)的源对象是否实现了 INotifyPropertyChanged接口(interface),如果是,它订阅 PropertyChanged幕后事件。确切地说,在 WPF 内部如何处理这是一个您不必真正关心或应该依赖的实现细节。

关于c# - 将控件绑定(bind)到对象是否算作订阅?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50623277/

相关文章:

c# - 反转对象或用减号将其标记为负数

c# - 并行化作业的更好方法

c# - 如何更改 UWP 中的 AppBarButton FontSize?

wpf - 什么是 WPF 预览事件?

c# - 用 C# 编写全局自定义事件

events - Angular 5 ngSubmit @Output 触发两次

c# - 如何使用 C# 将 html 文本转换为 utf-8

c# - 使用 C# 在 VisualBrush 中设置图像运行时

c# - 如何访问 C# 属性的方法? (特别是如果属性是一个集合并使用 INotifyPropertyChanged 接口(interface))

MySQL 说 : #1064 - You have an error in your SQL syntax;