0

Symfony2 / twig は初めてで、事前に保存された値でフォームをレンダリングする必要があります。

データをロード/保存するフォームを取得できますが、事前に保存された値を表示することはできません。私は何が欠けていますか?

これが私のコントローラーコードです:

/**
 * @Route("/build/{id}")
 * @Template()
 */
public function buildAction($id)
{
    $request = $this->getRequest();
    $em = $this->getDoctrine()->getEntityManager();
    $repo = $em->getRepository('ImagineNewsletterBundle:Section');
    $section = $repo->find($id);


    $newsletter = $section->getNewsletter();
    $globalMag = $newsletter->getMagazine();

    //$globalMag = unserialize($globalMag[0]);


    $builder = $this->get('newsletter.builders')->getBuilder($section->getBuilder());
    $builder->setSearchUrl($this->generateUrl('imagine_newsletter_section_search', array('builder' => $section->getBuilder())));

    $form = $this->createForm($builder->getSearchFormBuilder());    

    $prevArticles = $section->getArticles();      

   // $form->bind($prevArticles);


    return $this->render('ImagineNewsletterBundle:Section:'.$builder->getTemplate() , array('prevArticles' => $prevArticles,'builder' => $builder, 'form' => $form->createView(), 'section' => $section, 'newsletter' => $newsletter,  'globalmag' => $globalMag));
}

ここに私の小枝/フォームコード:

<form id="advert" action="{{ addAticle }}" method="post" {{ form_enctype(form) }} class="form-stacked">

                    <div class="form_element">
                        {{ form_label(form.topLogoAdvert) }}
                        {{ form_errors(form.topLogoAdvert) }}
                        {{ form_widget(form.topLogoAdvert) }}
                    </div>

                    <div class="form_element">
                        {{ form_label(form.topLogoAlt) }}
                        {{ form_errors(form.topLogoAlt) }}
                        {{ form_widget(form.topLogoAlt) }}
                    </div>


                    <div class="form_element">
                        {{ form_label(form.topLogoLink) }}
                        {{ form_errors(form.topLogoLink) }}
                        {{ form_widget(form.topLogoLink) }}
                    </div>

                    <input type="hidden" name="section" value="{{ section.id }}" />

                        {{ form_widget(form) }}

                        <div class="well">
                            <button type="submit" class="btn primary">Save</button>
                            <button id="reset" type="reset" class="btn">Reset</button>
                        </div>
                        {{ form_rest(form) }}
                </form>
4

2 に答える 2

1

フォームをリクエストにバインドする必要があります。これにより、ユーザーが入力したデータがフォームに入力されます。コードを更新しました。

$request = $this->getRequest();
$em = $this->getDoctrine()->getEntityManager();
$repo = $em->getRepository('ImagineNewsletterBundle:Section');
$section = $repo->find($id);

$builder = $this->get('newsletter.builders')->getBuilder($section->getBuilder());
$builder->setSearchUrl($this->generateUrl('imagine_newsletter_section_search', array('builder' => $section->getBuilder())));

$form = $this->createForm($builder->getSearchFormBuilder(), $section);

if ($request->isMethod('post')) {
    $form->bind($request);
}

return $this->render('ImagineNewsletterBundle:Section:'.$builder->getTemplate() , array('builder' => $builder, 'form' => $form->createView(), 'section' => $section));

また、フォームがユーザーによって送信されたときに、フォームを出力するアクションに移動することを確認する必要があります。フォームを処理するための別のアクションがあると思います。

于 2013-08-08T15:19:52.510 に答える