INotifyPropertyChanged:安全
該接口包含一個事件, 針對屬性發生變動時, 執行該事件發生。函數
// // 摘要: // 通知客戶端屬性值已更改。 public interface INotifyPropertyChanged { // // 摘要: // 在屬性值更改時發生。 event PropertyChangedEventHandler PropertyChanged; }
接下來, 用一個簡單的示例說明其簡單使用方法(大部分經常使用的作法演示):性能
1.定義一個ViewModelBase 繼承INotifyPropertyChanged 接口, 添加一個虛函數用於繼承子類的屬性進行更改通知this
2.MainViewModel中兩個屬性, Code,Name 進行了Set更改時候的調用通知,spa
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的時候, 都須要傳一個本身的屬性名, 這樣是否是不少餘?對, 不少餘。code
改造blog
1.看到有些文章給基類的參數修改成表達式樹, 這樣實現的時候,傳遞一個Lambda表達式, 我以爲這是不治標不治本嗎?以下: 繼承
說明: 原來直接傳遞一個固定的string類型實參, 不說換成lambda的性能問題, 一樣帶來的問題你仍是固定的須要去書寫這個參數。 不建議這麼作!接口
CallerMemberName事件
該類繼承與 Attribute, 不難看出, 該類屬於定義在方法和屬性上的一種特效類, 實現該特性容許獲取方法調用方的方法或屬性名稱
// // 摘要: // 容許獲取方法調用方的方法或屬性名稱。 [AttributeUsage(AttributeTargets.Parameter, Inherited = false)] public sealed class CallerMemberNameAttribute : Attribute { // // 摘要: // 初始化 System.Runtime.CompilerServices.CallerMemberNameAttribute 類的新實例。 public CallerMemberNameAttribute(); }
改造ViewModelBase:
改造以後, 是否是發現明顯區別:
不用傳遞參數, 不用書寫lambda表達式, 也不用擔憂其傳遞的參數安全, 直接根據讀取屬性名!