![]() |
![]() |
![]()
Post
#1
|
|
Grupa: Zarejestrowani Postów: 743 Pomógł: 0 Dołączył: 11.11.2003 Skąd: Toruń Ostrzeżenie: (0%) ![]() ![]() |
Witam,
znów mam problem z zaplanowaniem przepływu wszystkich danych w aplikacji. Wedle poprzednich podpowiedzi, które uzyskałem na forum zrobiłem tak (na przykładzie dodawania newsa): NewsModel.php
NewsController.php
No i niby wszystko dziala ladnie, mam kontroler ktory przekazuje dane do modelu, model te dane zapisuje i wszystko jest good. Ale teraz gdy planuję dodać nową kolumnę w bazie danych, muszę modyfikować Model, wszystkie kontrolery które uzyły danego Modelu. Dodatkowo jeśli gdzieś nie zmienię kontrolera to np. content zapisze mi sie jako title, bo zmieni sie kolejnosc zmiennych wchodzących do funkcji i wszystko sie pokrzaczy. Dobrze to robię, twrząc dla każdego zadania nową funkcję w modelu i przekazując do niej dane jako parametry funkcji? I też pytanie czy to nie jest bez sensu takie duplikowanie wielu funkcji które dostarcza mi ORM Propel. Np. żeby pobrać newsa o danym id, napisąłem funkcję w modelu:
Ale przecież równie dobrze mogłem od razu w kontrolerze pobrać newsa za pomocą funkcji dostarczonych przez ORM:
Jakie mam korzyści z przerzucania zadań do modelu. Nie dodaję sobie tym zbędnej pracy, pisząc masę metod które w sumie już posiadam? Ten post edytował Kuziu 14.02.2011, 12:20:02 |
|
|
![]() |
![]()
Post
#2
|
|
Grupa: Zarejestrowani Postów: 6 476 Pomógł: 1306 Dołączył: 6.08.2006 Skąd: Kraków Ostrzeżenie: (0%) ![]() ![]() |
Cytat I czy powinienem przekazywać zawsze $user, a w kontrolerze pobierać aktualnie zalogowanego, czy Model sam powinien pobierać aktualnie zalogowanego user'a i domyslnie do niego przypisywać dane. Model powinien jawnie otrzymać referencję do użytkownika jeżeli ta potrzebna jest mu do pracy. Generalnie to taka złota zasada OOP: nigdy nie wytwarzaj "z dupy" zależności. Innymi słowy - obiekt nie powinien korzystać z jakiś globalnych danych (chyba, że jest to naprawdę nieuniknione).Dodatkowo powinieneś bardziej uważnie projektować publiczny interfejs Twoich obiektów. UserModel::addFavouritePhoto($user, $photo); - Pomijając fakt błędnego użycia metody statycznej (powinieneś operować na obiekcie tutaj, nie na klasie) dodanie ulubionego zdjęcia raczej powinno odbywać się na poziomie obiektu użytkownika:
|
|
|
![]() ![]() |
![]() |
Aktualny czas: 6.10.2025 - 04:06 |