![]() |
![]() ![]() |
![]() |
![]()
Post
#1
|
|
Grupa: Zarejestrowani Postów: 191 Pomógł: 7 Dołączył: 3.04.2013 Ostrzeżenie: (0%) ![]() ![]() |
Chcę tutaj porównać jedną daną pobraną w przesyłanym formularzu z drugą.
Wyczytałem gdzieś że do rozwiązania tego problemu, przy tworzeniu formularza FormType należy wykorzystać obiekt Callback, konstrukcja wygląda mniej więcej tak:
Problem w tym że nie wiem gdzie mam umieścić funckję validate. Umieszczałem ją w FormType i nie działa, także próbowałem w kontrolerze, ale tam też jakoś na to nie reaguje. Przy formularzu wykorzystującym entity, umieszczam ją w entity i wszystko działa, ale tutaj nie mam takiej klasy. Więc, gdzie umieścić tą funkcję? ![]() |
|
|
![]()
Post
#2
|
|
![]() Grupa: Zarejestrowani Postów: 6 476 Pomógł: 1306 Dołączył: 6.08.2006 Skąd: Kraków Ostrzeżenie: (0%) ![]() ![]() |
A skąd wziąłeś sobie niby zmienną $data w metodzie validate()? Masz tam dostęp do obiektu ExecutionContextInterface i przez niego powinieneś jak już dobrać się do właściwości poszczególnych pól.
|
|
|
![]()
Post
#3
|
|
Grupa: Zarejestrowani Postów: 191 Pomógł: 7 Dołączył: 3.04.2013 Ostrzeżenie: (0%) ![]() ![]() |
$data powinienem brać z formularza:
Wygląda na to że miałbym umieścić tą funkcję w kontrolerze, ale wydaje mi sie że to nie jest dobra praktyka. Mam stworzyć oddzielną klase walidacji dla tego przypadku? np. class validatePole? Ten post edytował Crash89 16.07.2015, 13:48:52 |
|
|
![]()
Post
#4
|
|
![]() Grupa: Zarejestrowani Postów: 6 476 Pomógł: 1306 Dołączył: 6.08.2006 Skąd: Kraków Ostrzeżenie: (0%) ![]() ![]() |
Komponent od walidacji danych nie ma na dobrą sprawę zbyt dużego pojęcia na temat czegoś takiego jak "formularz". Pod $context->getValue() zostanie zwrócona Ci wartość, która jest akutualnie poddawana sprawdzaniu. Możesz w tym miejscu dokonać porównania dwóch właściwości i w przypadku błędu za pomocą $context->buildViolation() dodać błąd.
|
|
|
![]()
Post
#5
|
|
Grupa: Zarejestrowani Postów: 82 Pomógł: 22 Dołączył: 20.07.2010 Ostrzeżenie: (0%) ![]() ![]() |
Co to znaczy nie dziala?
Nie dziala bo zgodnie z dokumentacja: http://symfony.com/doc/current/reference/c...callback-option callback dostaje: Concrete callbacks receive an ExecutionContextInterface instance as only argument. Static or closure callbacks receive the validated object as the first argument and the ExecutionContextInterface instance as the second argument. Wiec Twoja metoda validate jest w dobrym miejscu (tzn moglaby byc gdzie indziej niz w form type, ale tutaj tez jest ok), ale powinna miec taka sygnature: public function validate($value, ExecutionContextInterface $ec). Tak jak ty masz powinienes dostac: Catchable Fatal Error: Argument 1 passed to AppBundle\Form\TestType::validate() must implement interface Symfony\Component\Validator\Context\ExecutionContextInterface, string given albo cos podobnego - bylby to lepszy komunikat niz "nie dziala". Jesli nie widzisz tych bledow to polecam developowac przez kontroler developerski ![]() Dla pewnosci wysylam przykladowy form type, ktory dziala. Jesli w pole "Pole" wpiszemy "a" to formularz jest prawidlowy, a jesli b to dostaniemy blad podpiety pod pole: Pole musi byc a
no i kontroler:
|
|
|
![]()
Post
#6
|
|
Grupa: Zarejestrowani Postów: 191 Pomógł: 7 Dołączył: 3.04.2013 Ostrzeżenie: (0%) ![]() ![]() |
Dzięki waszym postom udało mi sie rozwiązać problem
![]() Ostatecznie rozwiązałem to tak: W klasie FormType umieściłem funkcję validate.
|
|
|
![]()
Post
#7
|
|
Grupa: Zarejestrowani Postów: 82 Pomógł: 22 Dołączył: 20.07.2010 Ostrzeżenie: (0%) ![]() ![]() |
jest ok, ale jesli ta metoda walidacji ma dotyczyc calego formularza (bo uzywa wiekszej ilosci pol) to moze byc lepszym pomyslem dodanie walidatora do calego formularza, a nie do pojedynczego pola.
Do klasy FormType mozna dodac metode:
Wtedy w metodzie validate w 1 argumencie dostaniemy array z wszystkimi polami z formularza (pola nie powinny miec mapped => false, i tak nie przekazujemy obiektu):
|
|
|
![]()
Post
#8
|
|
Grupa: Zarejestrowani Postów: 191 Pomógł: 7 Dołączył: 3.04.2013 Ostrzeżenie: (0%) ![]() ![]() |
jest ok, ale jesli ta metoda walidacji ma dotyczyc calego formularza (bo uzywa wiekszej ilosci pol) to moze byc lepszym pomyslem dodanie walidatora do calego formularza, a nie do pojedynczego pola. Do klasy FormType mozna dodac metode:
Wtedy w metodzie validate w 1 argumencie dostaniemy array z wszystkimi polami z formularza (pola nie powinny miec mapped => false, i tak nie przekazujemy obiektu):
Używając powyższej metody, zwraca mi komunikat podobny do: "cannot use DateTime as Array". Co jest dziwne, bo gdy porównuje te wartości z $value['pole1'] z $form->get('pole1')->getData() przez var_dump(), są takie same. |
|
|
![]()
Post
#9
|
|
Grupa: Zarejestrowani Postów: 82 Pomógł: 22 Dołączył: 20.07.2010 Ostrzeżenie: (0%) ![]() ![]() |
Moze zmieniles funkcje validate a zostawiles constraint tez dla pola, tak jak miales wczesniej. Dlatego dalej wartosc datetime przekazywana jest do funkcji validate.
Jesli nie, to znowu przydalby sie kod ![]() |
|
|
![]() ![]() |
![]() |
Aktualny czas: 22.08.2025 - 11:32 |