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。
推薦閱讀:
- C#優雅的實現INotifyPropertyChanged接口
- WPF中使用CallerMemberName簡化InotifyPropertyChanged的實現
- C# WPF數據綁定模板化操作的完整步驟
- c# Winform同一數據源多個控件保持同步
- c# 基於GMap.NET實現電子圍欄功能(WPF版)