Sto lavorando alla creazione di un'applicazione MVP (C# Winforms). La mia versione iniziale è a Critique my simple MVP Winforms app ... Ora sto aumentando la complessità. Ho scomposto il codice per gestire due campi di testo separati in due coppie vista/presentatore. È un esempio banale, ma è elaborare i dettagli di più relatori che condividono lo stesso modello.Condivisione del modello nell'app MVP Winforms
Le mie domande sono circa il modello:
sto fondamentalmente usando un evento modificato proprietà sfoggiata dal modello per la notifica di una vista che qualcosa è cambiato. E 'un buon approccio? Cosa succede se arriva al punto in cui ho 100 o 1000 proprietà? È ancora pratico a quel punto?
Is Instantiating il modello in ogni presentatore con
NoteModel _model = NoteModel.Instance
l'approccio corretto? Si noti che voglio essere sicuro che tutti i relatori condividano gli stessi dati.Se v'è un approccio migliore, io sono aperto a suggerimenti ....
Il mio codice simile a questo:
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 è essenzialmente lo stesso eccetto che funziona su _model.MoreText
anziché _model.TheText
.
ITextEditorView.cs
public interface ITextEditorView
{
string TheText { get; set; }
}
ITextEditor2View.cs
public interface ITextEditor2View
{
string MoreText { get; set; }
}
+1 Ottima domanda. Sto avendo lo stesso nella mia mente. – Marcel