0

我正在 Symfony2 中构建一个页面,允许我在我的数据库中搜索一个术语(例如一个人的名字)并在同一页面中显示(即使在页面重新加载之后)所有匹配的记录(例如所有具有此名称的人)。

这是我的 anagrafica.html.twig

{# src/Acme/MyBundle/Resources/views/Page/anagrafica.html.twig #}
{% extends 'AcmeMyBundle::layout.html.twig' %}

{% block body %}

    <form id="formsearch" name="p" method="get" action="anagrafica">
        <span>
            <input type="text" name="search_name"  id="search_name" />
        </span>
        <input type="image" name="button_search" />
    </form>

    {% for anagrafica in anagrafiche %}
        <article class="blog">
            <div class="date">{{ anagrafica.DataNascita|date('c') }}</div>
            <header>
                <h2><a href="{{ path('AcmeMyBundle_showAnag', { 'id': anagrafica.id }) }}">{{ anagrafica.nome }}</a></h2>
            </header>
            <div class="snippet">
                <p>{{ anagrafica.cognome }}</p>
                <p class="show_complete"><a href="{{ path('AcmeMyBundle_showAnag', { 'id': anagrafica.id }) }}">Show all data</a></p>
            </div>
        </article>
    {% else %}
        <p>There are no entries</p>
    {% endfor %}
{% endblock %}

这是我的 PageController.php

<?php // src/Acme/MyBundle/Controller/PageController.php

namespace Acme\MyBundle\Controller;

use Symfony\Bundle\FrameworkBundle\Controller\Controller;

class PageController extends Controller {
    //...
    public function anagraficaAction() {    
        $em = $this->getDoctrine()
            ->getEntityManager();

        $anagrafiche = $em->createQueryBuilder()
            ->select('b')
            ->from('AcmeMyBundle:Anagrafiche',  'b')
            ->where("b.nome = :nome")
            ->setParameter('nome', 'Alex' )
            ->addOrderBy('b.id', 'DESC')
            ->getQuery()
            ->getResult();

        return $this->render('AcmeMyBundle:Page:anagrafica.html.twig', array('anagrafiche' => $anagrafiche));
    }
}

我想我只需要更新我的 PageController.php 并将名称替换为'Alex' in : ->setParameter('nome', 'Alex' ) 一个变量,该变量引用我在 anagrafica.html.twig 中定义的表单中的条目。无论如何,我不知道如何做到这一点,在谷歌和论坛上的快速搜索对我没有帮助。

有什么建议吗?

4

3 回答 3

2

您通过以下方式获得 GET 参数

$searchName = $request->query->get('search_name');

但是为此,您仍然需要该$request变量。您可以将其用作参数并将您的方法签名更改为:

public function anagraficaAction(Request $request)

这样,您可以$request在方法中调用参数。

另一种方法是在您的方法中获取当前控制器的请求。

$request = $this->get('request');

使用这个你可以改变你setParameter的:

setParameter('nome', $searchName)
于 2013-09-26T10:36:55.153 回答
0

将其更改setParameter('nome', 'Alex')为类似的内容,setParameter('nome', $_GET['search_name'])因为此表单使用 get 方法传递数据。

于 2013-09-26T09:24:55.740 回答
0

我找到了解决方案。我编辑了我的 PageController.php 这样的:

<?php
// src/Acme/MyBundle/Controller/PageController.php

namespace Acme\MyBundle\Controller;

use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Symfony\Component\HttpFoundation\Request;

class PageController extends Controller
{
    public function indexAction()
    {
        return $this->render('AcmeMyBundle:Page:index.html.twig');
    }

    public function infoAction()
    {
       return $this->render('AcmeMyBundle:Page:info.html.twig');
    }

    public function anagraficaAction(Request $request)
    {


       $em = $this->getDoctrine()
       ->getEntityManager();

$title = $request->get('search_name');


       $anagrafiche = $em->createQueryBuilder()
       ->select('b')
       ->from('AcmeMyBundle:Anagrafiche',  'b')
       ->where("b.nome = :nome")
       ->setParameter('nome', $title )
       ->addOrderBy('b.id', 'DESC')
       ->getQuery()
       ->getResult();

       return $this->render('AcmeMyBundle:Page:anagrafica.html.twig', array('anagrafiche' => $anagrafiche));
    }

}
于 2013-09-30T06:11:26.637 回答