C#接口INotifyPropertyChanged使用方法

INotifyPropertyChanged:

該接口包含一個事件, 針對屬性發生變更時, 執行該事件發生。

    //
    // 摘要:
    //     通知客戶端屬性值已更改。
    public interface INotifyPropertyChanged
    {
        //
        // 摘要:
        //     在屬性值更改時發生。
        event PropertyChangedEventHandler PropertyChanged;
    }

接下來, 用一個簡單的示例說明其簡單使用方法(大部分常用的做法演示):

1.定義一個ViewModelBase 繼承INotifyPropertyChanged 接口, 添加一個虛函數用於繼承子類的屬性進行更改通知

2.MainViewModel中兩個屬性, Code,Name 進行瞭Set更改時候的調用通知,

     public class ViewModelBase : INotifyPropertyChanged
    {
        public event PropertyChangedEventHandler PropertyChanged;

        protected virtual void OnPropertyChanged(string propertyName)
        {
            if (this.PropertyChanged != null)
                this.PropertyChanged(this, new PropertyChangedEventArgs(propertyName));
        }
    }


    public class MainViewModel : ViewModelBase
    {
        private string name;
        private string code;

        public string Name
        {
            get { return name; }
            set { name = value; OnPropertyChanged("Name"); }
        }

        public string Code
        {
            get { return code; }
            set { code = value; OnPropertyChanged("Code"); }
        }
    }

正如上面的代碼, 應該註意到瞭, 每個屬性調用OnPropertyChanged的時候, 都需要傳一個自己的屬性名, 這樣是不是很多餘?對, 很多餘。

改造

看到有些文章給基類的參數修改為表達式樹, 這樣實現的時候,傳遞一個Lambda表達式, 我覺得這是不治標不治本嗎?如下:

說明: 原來直接傳遞一個固定的string類型實參, 不說換成lambda的性能問題, 同樣帶來的問題你還是固定的需要去書寫這個參數。 不建議這麼做!

CallerMemberName

該類繼承與 Attribute, 不難看出, 該類屬於定義在方法和屬性上的一種特效類, 實現該特性允許獲取方法調用方的方法或屬性名稱

    //
    // 摘要:
    //     允許獲取方法調用方的方法或屬性名稱。
    [AttributeUsage(AttributeTargets.Parameter, Inherited = false)]
    public sealed class CallerMemberNameAttribute : Attribute
    {
        //
        // 摘要:
        //     初始化 System.Runtime.CompilerServices.CallerMemberNameAttribute 類的新實例。
        public CallerMemberNameAttribute();
    }

改造ViewModelBase:

改造之後, 是不是發現明顯區別:

不用傳遞參數, 不用書寫lambda表達式, 也不用擔心其傳遞的參數安全, 直接根據讀取屬性名!

到此這篇關於C#接口INotifyPropertyChanged使用方法的文章就介紹到這瞭。希望對大傢的學習有所幫助,也希望大傢多多支持WalkonNet。

推薦閱讀: