214 похожих чатов

Я не согласен, и попробую обьяснить на примере. Существует паттерн MVP.

Идея одна.
Сущесутет фреймворк, который реализует этот паттерн.
Мокси.
Мосби.
Можно без фреймворка.

Паттерн один. Реализации уже 3.

Если отталкиваться от того, что паттерн стимулирует написание бойлерплейта, то это означает, что все три реализации одинаково много предоставляют его. Что не верно, потому что последний явно больше требует написания кода, который можно было орагинзовать.

Как следствие: бойлерплейт порождается реализацией того или иного паттерна, а не его идеей.

А теперь предлагаю вернуться в начало обсуждения логики и где ей место быть:

- Ну тут как посмотреть, в акторах MVICore и в редьюсерах TEA может спокойно размещаться вся бизнес логика фичи.
- она то может, но место ли ей там?

Это вопросы не на уровне реализации, а на уровне проектирования (ака идеи реализации)

- Да, можно использовать MVI чисто как презентационный паттерн и тогда выходит тот же MVP только сбоку
- То-что MVP , но только сбоку, так это же и замечательно.

замечательно потому что они оба представляют собой идею коммуникации между слоями отображения и модели.
Они решают одну цель
Они на уровне идеи делают это разными способами коммуникации
На уровне реализации они делают это еще более разными способами

Обьясню это таким образом.

Если бы MVI был паттерном для Модели, то при таком подходе конкретную реализации модели отличалась бы от той, что у нас есть в MVP, или, они были бы не совместимы.

Но при правильной реализацией MVP мы можем иметь абсолютно такую же реализацию модели как и в MVI, но на уровне соединения Модели и Отображения:
- МВП бы получал изменения с модели по подписке и отправлял их на Вью через команды, а события в Презентер отправлялись бы тоже командами
- MVI бы получал изменения с модели по подписке и редюсил бы их в ViewState, который бы отправлялся во вью через метод render, а получение данных происходило бы по подписке на вью.

1 ответов

17 просмотров

> Если отталкиваться от того, что паттерн стимулирует написание бойлерплейта, то это означает, что все три реализации одинаково много предоставляют его. Что не верно, потому что последний явно больше требует написания кода, который можно было орагинзовать. если паттерн требует написания бойлерплейта, то любая его реализация не может предоставить меньше бойлерплейта. Больше - сколько угодно. MVP с долгоживущим презентером требуют как минимум задекларировать интерфейс view и иметь способ для сохранения состояния между пересозданиями вью > как итог: нет реализации Модели по MVI, и нет реализации модели по MVP. сорян, но это доказательство через утверждение какое-то. "я использую MVI только как презентационный паттерн и поэтому бизнес логику в него помещать нельзя"

Похожие вопросы

Обсуждают сегодня

Добрый вечер. Есть вопрос, а может и предложение. Был у меня диалог в другой группе о делфи и я задался вопросом: "А нельзя ли в делфи цвет //коментария и {комментария} сде...
Kraszx
24
Всем привет! Подскажи, пожалуйста, как передать в TComboBox сразу значение и id записи. На Delphi я делал так: ComboBox1.Items.AddObject('Какое-то значение', Pointer(id запис...
Евгений
13
Мдя, прикол, боевая сборка запускается (именно под отладчиком) после F9 примерно полторы минуты (97 секунд если быть точным). Начал копать - проблема детектится сразу - зависа...
Александр (Rouse_) Багель
38
я так понимаю, я так подозреваю, что создание такого плагина для человека, кто умеет писать плагины для делфи потребует минут 5-10 времени. но это мое подозрение. хотелось бы ...
Kraszx
7
Товарищи, кто работа с iphelper? Или может я в самой логике ошибки фигачу, не пойму.... var ifTable : PMIB_IFTABLE; size, corSize: DWORD; Buffer ...
Warfarellen
4
Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
50
Коллеги, добрый вечер. Создаю коллекцию от TFPGMap, ключ - перечисление, значение - целое. Нужно отсортировать коллекцию по значению. Как это можно сделать?
Kirill Filippenok
11
Ребята, всем привет. Подскажите, пожалуйста, можно ли как-то через бота понять, что этого бота добавили в группу\канал и выдали ему права администратора?
Artem Stormageddon
9
Скажи а ты когда этот канал создавал ты уже дельфи не любил, или это со временем пришло?
Роман Лях (rgreat)
18
Привет, такой вопросик появился кажется ли вам что Rust слишком сложный/строгий для высокоуровневого программирования и слишком "безопасный"/строгий для низкоуровневого?
Крокант
10
Карта сайта