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

Symfony form, nie mogę obsłużyć requestu wysłanego przez ajax

Aruba Cloud PRO i VPS, Openstack, VMWare, MS Hyper-V
0 głosów
138 wizyt
pytanie zadane 7 września 2022 w PHP przez Filipczak Gaduła (4,000 p.)

Cześć, próbuję obsłużyć request, który zawiera dane z formularza, używając ajaxa. Jednak gdy już zrobiłem to zapytanie, nie mogę tego obsłużyć tak jak w normalnym przypadku bez ajaxa używając:

$form->isSubmitted() && $form->isValid()

próbowałem zrobić osobne ify, aby sprawdzić czy działa form->isSubmitted, bez $form->isValid i nie dało to żadnego efektu, bo po prostu te ify się nie uruchamiały.

Mój skrypt renderujący wygląd
 

 public function index(Request $request, EntityManagerInterface $entityManager): Response
    {
        $category = new Category();

        $list = $entityManager->getRepository(Category::class)->listCategory();

        return $this->render('admin/index/category.html.twig', [
            'categoryForm' => $form->createView(),
            'list'         => $list
        ]);
    }

mój ajax

$(document).ready(function(){
    $("#category-add").submit(function(e){
        e.preventDefault();

        var form = $(this);

        $.ajax({
            type: "PUT",
            url: '/api/admin/category',
            data: form.serialize(),
            dataType: 'x-www-form-urlencoded',
            success: function(data)
            {
                console.log(data);
            }
        });
    });
});

Skrypt w którym próbuje obsłużyć request

 public function add(Request $request, EntityManagerInterface $entityManager): Response
    {
        $category = new Category();
        $form = $this->createForm(CategoryFormType::class, $category);
        $form->handleRequest($request);


        if ($form->isSubmitted() && $form->isValid()) {
            $category->setCategoryName($form->get('categoryName')->getData());

            $entityManager->persist($category);
            $entityManager->flush();

            return new response('true');        
        }
        return new response('false');
    }
}

twig template

                                        <form id="category-add">
                                            <input type="hidden" name="csrf_token" value="{{ csrf_token('add-category') }}" />
                                            <input type="text" name="categoryName" placeholder="Nazwa kategorii" class="w-full bg-black border border-grey-one rounded px-4 py-2 focus:outline-none text-sm text-white-two mb-4" />
                                            <button class="w-full uppercase bg-green-three px-6 py-3 rounded-md text-white font-semibold tracking-wide text-xs focus:outline-none" type="submit">Dodaj</button>
                                        </form>

 

2 odpowiedzi

+1 głos
odpowiedź 7 września 2022 przez Comandeer Guru (593,920 p.)

Hm, a problemem nie jest to, że robisz Ajaksa metodą PUT? Ta metoda nie jest dostępna z poziomu formularzy, więc być może dlatego Symfony uważa, że formularz nie został wysłany.

0 głosów
odpowiedź 8 września 2022 przez Ehlert Ekspert (210,490 p.)
Założę się że źle ustawiłeś name. Sprawdź czy isValid zwraca false, czy isSubmitted. Sprawdź jakie dane dostajesz. Ustaw data class dla formularza, to dobra praktyka.

Spróbuj wyrenderować formularz za pomocą twiga i porównaj HTML ze swoim.

Podobne pytania

–1 głos
2 odpowiedzi 345 wizyt
pytanie zadane 1 lipca 2019 w PHP przez mi-20 Stary wyjadacz (13,140 p.)
0 głosów
1 odpowiedź 194 wizyt
pytanie zadane 21 maja 2019 w PHP przez hiper007 Stary wyjadacz (11,270 p.)
0 głosów
1 odpowiedź 109 wizyt
pytanie zadane 27 lipca 2018 w PHP przez sapero Gaduła (4,100 p.)

91,832 zapytań

140,504 odpowiedzi

316,990 komentarzy

61,163 pasjonatów

Motyw:

Akcja Pajacyk

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

Oto dwie polecane książki warte uwagi. Pełną listę znajdziesz tutaj.

...