在Symfony2 / Twig中预填充表单值

时间:2013-08-08 14:09:26

标签: symfony twig

我是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>

2 个答案:

答案 0 :(得分: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));

您还需要确保当用户提交表单时,它会转到输出表单的操作。我现在怀疑你有一个单独的行动来处理表格。

答案 1 :(得分:0)

  1. 创建自定义FormType http://symfony.com/doc/current/cookbook/form/create_custom_field_type.html

  2. 使用您想要的数据填充您的实体并将其传递给表单。 (来自database / staticly / api / etc.)

  3. 然后按照现有的答案,了解如何从实体获取数据到表单,这样当您显示表单时,您可以创建现有值:How to pass entity atribute value to form Symfony2?当然,而不是您创建的属性类型默认选择。