Я разрабатываю приложение, в котором похожие объекты находятся в двух местах с разными типами сбора, как показано ниже.
Модель:
class PersonModel {
public string Name { get;set;}
public List<Address> Addresses { get;}
public List<OtherType> OtherTypes { get;}
}
Аналогичная модель:
class PersonViewModel {
public string Name { get;set;}
public ObservableCollection<Address> Addresses { get; }
public ObservableCollection<OtherType> OtherTypes { get; }
}
Чтобы согласовать обе сущности, я подумал об использовании универсального интерфейса, который гарантирует, что оба реализуют все свойства, поэтому я создал нечто вроде этого:
public interface IPerson<T> where T: ICollection<T> {
string Name { get;set;}
T<Address> Addresses { get;}
T<OtherType> OtherTypes [ get; }
}
и классы будут
class PersonModel<List> {}
class personViewModel<ObservableCollection> {}
но компилятор не готов к компиляции моего интерфейса. :(
Говорит, что параметр типа "T" нельзя использовать с аргументом типа.
Причину, по которой я этого хочу, я хотел минимизировать преобразование типов из / в модель и viewModel.
Моя viewModel будет такой,
class PersonViewModel<T> : IPerson<T> {
public PersonViewModel(IPerson model){
this.Model = model;
}
internal PersonModel Entity {
get; set;
}
public string Name {
get{ return model.Name;}
set {model.Name = value;}
}
public T<Address> Addresses {
get { return model.Addresses.Cast<T>(); }
}
}
Предложите лучший способ синхронизации Model & ViewModel.