59

我有这样的课:

public class PersonViewModel : ViewModelBase //Here is the INotifyPropertyChanged Stuff
{
    public PersonViewModel(Person person)
    {
        PersonEntity = person;
    }

    public Person PersonEntity { 
        get { return PersonEntity.Name; }
        private set { PersonEntity.Name = value; RaisePropertyChanged("PersonEntity");
    }

    public string Name { 
        get { return PersonEntity.Name; }
        set { PersonEntity.Name = value; RaisePropertyChanged("Name");
    } 
    public int Age{ 
        get { return PersonEntity.Age; }
        set { PersonEntity.Age= value; RaisePropertyChanged("Age");
    } 

    public void ChangePerson(Person newPerson)
    {
        //Some Validation..
        PersonEntity = newPerson;
    }

我的文本框绑定到 ViewModel 的名称和年龄。如果我更改 ViewModel 中的 _person 对象,我是否必须再次为每个属性调用 RaisePropertyChanged 或者是否有办法自动执行此操作(在我的具体示例中,我有大约 15 个属性..)?

谢谢你的帮助。

干杯约瑟夫

4

2 回答 2

119

您可以使用nullstring.Empty中的属性名称来指示所有属性已更改PropertyChangedEventArgs这在PropertyChanged的​​文档中有所提及。

于 2009-12-07T13:48:02.353 回答
1

我用来解决问题的另一种解决方案是:首先设置值,然后通过在 my 中PropertyChangedEventArgs添加一个Set函数来调用ViewModelBase它,如下所示:

public class ViewModelBase : INotifyPropertyChanged
{
    protected bool Set<T>(ref T backingField, T value, [CallerMemberName] string propertyname = null)
    {
        // Check if the value and backing field are actualy different
        if (EqualityComparer<T>.Default.Equals(backingField, value))
        {
            return false;
        }

        // Setting the backing field and the RaisePropertyChanged
        backingField = value;
        RaisePropertyChanged(propertyname);
        return true;
   }
}

而不是这样做:

public string Name { 
    get { return PersonEntity.Name; }
    set { PersonEntity.Name = value; RaisePropertyChanged("Name");
} 

您现在可以通过执行以下操作来实现相同的目的:

public string Name { 
    get { return PersonEntity.Name; }
    set { Set(ref PersonEntity.Name,value);
} 
于 2019-07-25T20:23:54.077 回答