我正在尝试将我的 C# WPF 应用程序从非 MVVM“移植”到 MVVM,但我正在努力处理类的继承。
我在我的模型中建立了一些层次结构:
银行包含一组补丁,其 IsSelected 绑定(bind)到银行 ListView 。
public abstract class Bank: ObservableCollectionEx<Patch>
{
...
bool _isSelected;
public bool IsSelected
{
get { return _isSelected; }
set { if (value != _isSelected) { _isSelected = value; OnPropertyChanged(new PropertyChangedEventArgs("IsSelected")); } }
}
...
补丁定义如下。唯一有趣的类(对于这个问题)是 ObservableObject。
public abstract class Patch : ObservableObject, IComparable<Patch>, INavigation, IParameter
{
...
ObservableCollection 定义为:
public class ObservableCollectionEx<T> : ObservableCollection<T> where T : ObservableObject
{
ObservableObject 定义为:
public abstract class ObservableObject : INotifyPropertyChanged
{
...
在我的 ViewModel 中,我需要一个选定银行的列表,所以我定义了它们:
public ObservableCollectionEx<Bank> Banks
{
get ...
然而,这给出了一个错误:
类型“PcgTools.Synths.Common.Synth.Bank”不能用作泛型类型或方法“ObservableCollectionEx”中的类型参数“T”。没有从“PcgTools.Synths.Common.Synth.Bank”到“ObservableObject”的隐式引用转换。 G:\Data\Eigen\Informatica\KorgKronosTools\KorgKronosTools\ViewModels\PcgViewModel.cs 152 45 PcgTools
我(认为)我需要这种结构,因为:
Bank 的 IsSelected 属性绑定(bind)到(银行) ListView (显示所有银行)。可以选择多个银行。所以银行应该支持 INotifyPropertyChange(ObservableObject 这样做)。
最佳答案
我的第一个问题是你为什么要这样做?但是,如果您确实需要,那么听起来对您的通用约束的唯一要求是该类型实现 INotifyPropertyChanged
:
public class ObservableCollectionEx<T> : ObservableCollection<T> where T : INotifyPropertyChanged
你不需要实现
INotifyPropertyChanged
在 Bank
由 ObservableCollection<T>
实现的类型您最好创建自己的接口(interface)(继承自
INotifyPropertyChanged
)并拥有您需要访问的方法。然后使用该自定义接口(interface)作为泛型类型的约束,并在 ObservableObject
中实现它和 ObservableCollectionEx
.
关于c# - Model/ViewModel 设计中的类继承错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9370135/