Я работаю над созданием приложения MVP (C # Winforms). Моя начальная версия на Критика моего простого приложения MVP Winforms ... Теперь я увеличиваю сложность. Я разбил код для обработки двух отдельных текстовых полей на две пары вид / презентатор. Это тривиальный пример, но он должен проработать детали нескольких докладчиков, использующих одну и ту же модель.
Мои вопросы по поводу модели:
Я в основном использую событие свойства, вызванное моделью, для уведомления представлений о том, что что-то изменилось. Это хороший подход? Что делать, если доходит до того, что у меня есть 100 или 1000 свойств? Это все еще практично в этот момент?
Является ли создание экземпляра модели в каждом докладчике с NoteModel _model = NoteModel.Instance
правильным подходом? Обратите внимание, что я хочу убедиться, что все докладчики используют одни и те же данные.
Если есть лучший подход, я открыт для предложений ....
Мой код выглядит так:
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 по сути тот же, за исключением того, что он работает на _model.MoreText
вместо _model.TheText
.
ITextEditorView.cs
public interface ITextEditorView
{
string TheText { get; set; }
}
ITextEditor2View.cs
public interface ITextEditor2View
{
string MoreText { get; set; }
}