Pracuję nad budowaniem aplikacji MVP (C# Winforms). Moja początkowa wersja to Critique my simple MVP Winforms app ... Teraz zwiększam złożoność. Podzieliłem kod, aby obsługiwać dwa oddzielne pola tekstowe na dwie pary widoków/prezentacji. Jest to banalny przykład, ale chodzi o to, aby poznać szczegóły wielu prezenterów, którzy dzielą ten sam model.Udostępnianie modelu w aplikacji WinForce MVP
Moje pytania są o modelu:
Ja w zasadzie za pomocą właściwości zmieniono zdarzenie podniesione przez model powiadamiania poglądy, że coś się zmieniło. Czy to dobre podejście? Co jeśli dojdzie do punktu, w którym mam 100 lub 1000 właściwości? Czy nadal jest to praktyczne?
Czy tworzenie wystąpienia modelu w każdym z prezenterów przy użyciu prawidłowego podejścia jest zgodne z
NoteModel _model = NoteModel.Instance
? Zauważ, że chcę się upewnić, że wszyscy prezenterzy dzielą te same dane.Jeśli jest lepszym rozwiązaniem, jestem otwarty na sugestie ....
Mój kod wygląda następująco:
NoteModel.cs
public class NoteModel : INotifyPropertyChanged
{
private static NoteModel _instance = null;
public static NoteModel Instance
{
get { return _instance; }
}
static NoteModel()
{
_instance = new NoteModel();
}
private NoteModel()
{
Initialize();
}
public string Filename { get; set; }
public bool IsDirty { get; set; }
public readonly string DefaultName = "Untitled.txt";
string _sText;
public string TheText
{
get { return _sText; }
set
{
_sText = value;
PropertyHasChanged("TheText");
}
}
string _sMoreText;
public string MoreText
{
get { return _sMoreText; }
set
{
_sMoreText = value;
PropertyHasChanged("MoreText");
}
}
public void Initialize()
{
Filename = DefaultName;
TheText = String.Empty;
MoreText = String.Empty;
IsDirty = false;
}
private void PropertyHasChanged(string sPropName)
{
IsDirty = true;
if (PropertyChanged != null)
{
PropertyChanged(this, new PropertyChangedEventArgs(sPropName));
}
}
public event PropertyChangedEventHandler PropertyChanged;
}
TextEditorPresenter .cs
public class TextEditorPresenter
{
ITextEditorView _view;
NoteModel _model = NoteModel.Instance;
public TextEditorPresenter(ITextEditorView view)//, NoteModel model)
{
//_model = model;
_view = view;
_model.PropertyChanged += new PropertyChangedEventHandler(model_PropertyChanged);
}
void model_PropertyChanged(object sender, PropertyChangedEventArgs e)
{
if (e.PropertyName == "TheText")
_view.TheText = _model.TheText;
}
public void TextModified()
{
_model.TheText = _view.TheText;
}
public void ClearView()
{
_view.TheText = String.Empty;
}
}
TextEditor2Presenter.cs jest zasadniczo taki sam, z wyjątkiem tego, że działa pod numerem _model.MoreText
zamiast _model.TheText
.
ITextEditorView.cs
public interface ITextEditorView
{
string TheText { get; set; }
}
ITextEditor2View.cs
public interface ITextEditor2View
{
string MoreText { get; set; }
}
+1 Świetne pytanie. Mam to samo w głowie. – Marcel