Поиск…


замечания

Интерфейс INotifyPropertyChanged необходим, когда вам нужно, чтобы ваш класс сообщал об изменениях, происходящих с его свойствами. Интерфейс определяет одно событие PropertyChanged .

С привязкой XAML событие PropertyChanged автоматически подключается, поэтому вам нужно реализовать интерфейс INotifyPropertyChanged для вашей модели представления или классов контекста данных для работы с привязкой XAML.

Внедрение INotifyPropertyChanged в C # 6

Реализация INotifyPropertyChange может быть подвержена ошибкам, так как интерфейс требует указания имени свойства как строки. Чтобы сделать реализацию более надежной, можно использовать атрибут CallerMemberName .

class C : INotifyPropertyChanged
{
    // backing field
    int offset;
    // property
    public int Offset
    {
        get
        {
            return offset;
        }
        set
        {
            if (offset == value)
                return;
            offset = value;
            RaisePropertyChanged();
        }
    }

    // helper method for raising PropertyChanged event
    void RaisePropertyChanged([CallerMemberName] string propertyName = null) =>
        PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));

    // interface implemetation
    public event PropertyChangedEventHandler PropertyChanged;
}

Если у вас несколько классов, реализующих INotifyPropertyChanged , вам может оказаться полезным реорганизовать реализацию интерфейса и вспомогательный метод для общего базового класса:

class NotifyPropertyChangedImpl : INotifyPropertyChanged
{
    protected void RaisePropertyChanged([CallerMemberName] string propertyName = null) =>
        PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));

    // interface implemetation
    public event PropertyChangedEventHandler PropertyChanged;
}

class C : NotifyPropertyChangedImpl
{
    int offset;
    public int Offset
    {
        get { return offset; }
        set { if (offset != value) { offset = value; RaisePropertyChanged(); } }
    }
}

INotifyPropertyChanged с помощью метода общего набора

В NotifyPropertyChangedBase ниже классе NotifyPropertyChangedBase определяется общий метод Set, который можно вызвать из любого производного типа.

public class NotifyPropertyChangedBase : INotifyPropertyChanged
{
    protected void RaisePropertyChanged([CallerMemberName] string propertyName = null) =>
    PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));
    
    public event PropertyChangedEventHandler PropertyChanged;

    public virtual bool Set<T>(ref T field, T value, [CallerMemberName] string propertyName = null)
    {
        if (Equals(field, value))
            return false;
        storage = value;
        RaisePropertyChanged(propertyName);
        return true;
    }
}

Чтобы использовать этот общий метод Set, вам просто нужно создать класс, который происходит из NotifyPropertyChangedBase.

public class SomeViewModel : NotifyPropertyChangedBase
{
    private string _foo;
    private int _bar;

    public string Foo
    {
        get { return _foo; }
        set { Set(ref _foo, value); }
    }

    public int Bar
    {
        get { return _bar; }
        set { Set(ref _bar, value); }
    }
}

Как показано выше, вы можете вызвать Set(ref _fieldName, value); в настройщике свойства, и он автоматически поднимет событие PropertyChanged, если это необходимо.

Затем вы можете зарегистрироваться в событие PropertyChanged из другого класса, который должен обрабатывать изменения свойств.

public class SomeListener
{
    public SomeListener()
    {
        _vm = new SomeViewModel();
        _vm.PropertyChanged += OnViewModelPropertyChanged;
    }

    private void OnViewModelPropertyChanged(object sender, PropertyChangedEventArgs e)
    {
        Console.WriteLine($"Property {e.PropertyName} was changed.");
    }

    private readonly SomeViewModel _vm;

}


Modified text is an extract of the original Stack Overflow Documentation
Лицензировано согласно CC BY-SA 3.0
Не связан с Stack Overflow