在 TWIG 中渲染控制器并显示表单错误

Render controller in TWIG and show form errors

我有 indexAction 和 contactAction

contactAction 是一个没有映射字段 (FormType) 的简单表单,如下所示:

/**
 * @Route("/contact", name="contact")
 * @Template()
 * @param Request $request
 * @return array
 */
public function contactAction(Request $request)
{
    $form = $this->createForm(new ContactType());

    $form->handleRequest($request);

    if ($form->isValid()) {
        $firstName = $form->get('first_name')->getData();
        $lastName = $form->get('last_name')->getData();
        $email = $form->get('email')->getData();
        $message = $form->get('message')->getData();
    }
    return array(
        'form' => $form->createView()
    );
}

然后我使用此 TWIG 命令在我的 indexAction 中呈现此表单:

{{ render(controller('RusselBundle:Default:contact')) }}

一切正常,如果页面没有重新加载,HTML5 验证器工作正常,但如果表单有一些错误,如:firstName 长度,错误根本不显示,我该怎么做,以便显示错误以 indexAction 的形式出现?任何帮助,将不胜感激。我只是好奇这是可能的,如果 - 怎么样?对不起我的英语....

如果您在 twig 中使用 render 函数,则会创建一个子请求,因此您最初发布的(即在您的主请求中)值会丢失。

您可以将主要请求传递给表单呈现操作,如下所示:

{{ render(controller('RusselBundle:Default:contact'), 'request' : app.request ) }}

这会将所有主要请求参数适当地传递给您的子请求。

您应该从请求堆栈中获取主请求,而不是使用传递到操作中的请求。正如@DebreczeniAndrás 所说,当您使用 render(controller()) 时,您使用的是新创建的子请求,而不是实际传递给加载页面的请求(主请求)。

public function contactAction(Request $request)
{
    $request = $this->get('request_stack')->getMasterRequest();

    $form = $this->createForm(new ContactType());

    //...
}

在 symfony3 上使用这样的渲染函数

{{ render(controller('RusselBundle:Default:contact', {'request':app.request})) }}