• 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

Object Storage Arubacloud
0 głosów
267 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 477 wizyt
pytanie zadane 11 stycznia 2017 w Java przez K0XM4N Gaduła (3,640 p.)
0 głosów
1 odpowiedź 347 wizyt
pytanie zadane 28 lutego 2016 w Systemy operacyjne, programy przez Daaa22 Dyskutant (8,250 p.)
0 głosów
1 odpowiedź 508 wizyt
pytanie zadane 14 października 2021 w Java przez Tajniakkk Użytkownik (600 p.)

92,551 zapytań

141,393 odpowiedzi

319,522 komentarzy

61,936 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

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy 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!

...