• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

MVC - pytanie dotyczące osadzenia kodu

VPS Starter Arubacloud
0 głosów
265 wizyt
pytanie zadane 9 listopada 2016 w Java przez K0XM4N Gaduła (3,640 p.)

Witam!

Już jakiś czas pisze sobie programy w Javie przy użyciu modelu MVC, lecz zastanawiam się czy robię to poprawnie. Zatem zwracam się do was forumowiczów, w jaki sposób powinno wyglądać osadzenie logiki aplikacji przy użyciu tego wzorca projektowego.

Weźmy za przykład Notatnik, który sobie teraz piszę z wykorzystaniem JavaFX.

Aplikacja składa się z trzech okienek. Jest to: notepad.fxml (główne okno), message.fxml(kominukat o zapisie) oraz font.fxml(wybór czcionki itd). Dla każdego widoku jest jeden kontroler, oprócz tego jedna klasa Modelu Notepad.
A tu mały screen struktury projektu:



I teraz mam wątpliwość co do projektowania aplikacji. Czy główna logika programu (otwieranie plików, zapisywanie ich, tworzenie nowego, wszelkie metody obsługi okien itd) powinna być porozrzucana po tych kontrolerach? Czy mają one być w jednej klasie np. w modelu gdzie potem tylko będę wywoływać odpowiednie metody w kontrolerach?

Obecnie mam aplikacje napisaną w ten sposób, że główna logika znajduje się w modelu Notepad, a kontrolery mają "wstrzyknięty" obiekt notepad i za pomocą tego obiektu wywołuje potrzebne mi metody.

Będę wdzięczny za rady i opinie, razie czego jestem w stanie rzucić kod gdyby była taka potrzeba :)

1 odpowiedź

+1 głos
odpowiedź 9 listopada 2016 przez Javowiec Pasjonat (21,560 p.)
Na Twoim miejscu stworzyłbym serwisy i w nich przechowywał logikę biznesową. Kontrolery nie byłyby tak przeładowane - delegowałyby zadania do serwisów.

Przykładowo MessageController mógłby mieć w sobie pole typu MessageService i wywoływać jego metody, które mają w sobie logikę biznesową.

A Model to Model, zwykłe gettery, settery i standardowe metody.
komentarz 9 listopada 2016 przez MichuDev Pasjonat (20,300 p.)
Model to struktura danych. Ponieważ każda metoda daje pełen dostęp do niego. Możesz użyć lomboka do wygenerowania getterów i setterów. Często lepiej użyć Domain Model (Model Domenowy), który ma swoją logikę. W końcu model może przedstawiać wszechświat. Dla człowieka na ziemi wydaje się, że ziemia stoi, a wszystko dookoła niej krąży, ale Kopernik wstrzymał słońce i ruszył ziemię, więc mimo innego punktu widzenia model może lub nie może wiedzieć co i jaką logikę wykonuje. Tutaj widać, że warto używać ekspertów domenowych, ponieważ mimo tego, że mamy taki punkt widzenia wszystko dzieje się odwrotnie.
komentarz 14 listopada 2016 przez K0XM4N Gaduła (3,640 p.)
Zatem odnosząc się do odpowiedzi Aventura, do każdego kontrolera stworzyć dodatkową klasę serwisową, posiadającą odpowiednią logike dla tego kontrolera?

Rzuć okiem na mój obecny kod, który wygląda tak:

http://pastebin.com/tRWprX7r (Notepad - model)

http://pastebin.com/D2piLT1m (NotepadController)

http://pastebin.com/VvZkGSDU (MessageController)

http://pastebin.com/remw5LWi (FontController)

Co o tym myślisz? Jakieś praktyczne uwagi dotyczące czystości kodu?

Podobne pytania

0 głosów
0 odpowiedzi 476 wizyt
pytanie zadane 11 stycznia 2017 w Java przez K0XM4N Gaduła (3,640 p.)
0 głosów
1 odpowiedź 339 wizyt
pytanie zadane 28 lutego 2016 w Systemy operacyjne, programy przez Daaa22 Dyskutant (8,250 p.)
0 głosów
1 odpowiedź 497 wizyt
pytanie zadane 14 października 2021 w Java przez Tajniakkk Użytkownik (600 p.)

92,452 zapytań

141,262 odpowiedzi

319,077 komentarzy

61,854 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia - użyjcie go w koszyku, a uzyskacie rabat -30% na bilety w wersji "Standard"! Więcej informacji na temat akademii 2024 znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...