0

我有简单的视图模型:

private List<Item> itemsList;
public List<Item> ItemsList
{
    get { return itemsList; }
    set
    {
        itemsList= value;
        NotifyPropertyChanged();
    }
}

private Item selectedItem;
public Item SelectedItem
{
    get { return selectedItem; }
    set
    {
        selectedItem = value;
        NotifyPropertyChanged();
    }
}

// I call this method from button handler 
// window code behind: vm.SaveChanges()
// instead of RelayCommand because I'm lazy (I don't need strict MVVM)
public void SaveChanges() 
{
    context.SaveChanges();
}

我的观点我有一个 ListView:

<ListView 
    ItemsSource="{Binding ItemsList}" 
    SelectedItem="{Binding SelectedItem}" 
/>

并且很少有带有 Item 属性的控件:

<TextBox Text="{Binding SelectedItem.Name}"/>
<TextBox Text="{Binding SelectedItem.Phone}"/>

当我在 ListView 上选择一个项目时 - SelectedItem 字段值出现在 TextBoxes 中,我可以编辑它们并保存它们。一切正常,但我不想让用户在保存更改之前更改选定的项目,因为用户不会看到另一个项目中的更改。

现在,当项目有未保存的更改时,我想禁用 ListView 上的选择更改。

我正在尝试这样的 ViewModel 属性:

public bool NoUnsavedChanges
{
    get { return !context.ChangeTracker.HasChanges(); }
    private set;
}

并将其绑定到 ListView 的 IsEnabled 属性,但它当然不起作用,因为该属性没有 NotifyPropertyChanged()。

我的问题是:如何在选定项目时禁用 ListView 选择更改(或完全禁用它)(或者如果整个上下文中有未保存的更改)?

4

1 回答 1

1

...并将其绑定到 ListView 的 IsEnabled 属性,但它当然不起作用,因为NotifyPropertyChanged(该属性没有 ) 。

然后发起一个PropertyChanged事件。您的视图模型应该实现INotifyPropertyChanged事件,您的Item类也应该实现。如果不是,你应该用一个包装类替换它。然后,只要状态发生更改,您就可以引发视图模型属性的PropertyChanged事件,例如:NoUnsavedChangesSelectedItem

private List<Item> itemsList;
public List<Item> ItemsList
{
    get { return itemsList; }
    set
    {
        itemsList = value;
        NotifyPropertyChanged();
    }
}

private Item selectedItem;
public Item SelectedItem
{
    get { return selectedItem; }
    set
    {
        if (selectedItem != null)
            selectedIten.PropertyChanged -= OnItemPropertyChanged;

        selectedItem = value;
        NotifyPropertyChanged();

        if (selectedItem != null)
            selectedIten.PropertyChanged += OnItemPropertyChanged;
    }
}

private void OnItemPropertyChanged(object sender, PropertyChangedEventArgs e)
{
    NotifyPropertyChanged("NoUnsavedChanges");
}

public bool NoUnsavedChanges
{
    get { return !context.ChangeTracker.HasChanges(); }
}

public void SaveChanges()
{
    context.SaveChanges();
    NotifyPropertyChanged("NoUnsavedChanges");
}
于 2018-07-16T10:08:44.370 回答