我正在尝试通过表格搜索使用KNP分页器。
一切正常,但是当我转到第2页时,他们将我带回到第2页,而没有搜索结果。
我在树枝上使用了POST方法,因为如果使用GET方法,则什么也没有发生。
我在此问题上发现了很多帖子,但我不知道该如何解决。如果有人对我有一些建议,请您能帮我吗。
这是我的代码:
public function rechercheAction() {
$form = $this->createForm(RechercheClientType::class);
return $this->render('admin/client/recherche.html.twig',[
'form' => $form->createView()
]
);
}
/**
* @Route("/admin/client/recherche", name="recherche_client")
*/
public function rechercheTraitementAction(PaginatorInterface $paginator,Request $request) {
$session = $request->getSession();
$form = $this->createForm(RechercheClientType::class);
$form->handleRequest($request);
$query = $this->repository->recherche($form['rechercheClient']->getData());
$users = $paginator->paginate(
$query,
$request->query->getInt('page',1), 10
);
//Compte le nombre d'éléments recherchés
$count = count($query);
return $this->render('admin/client/data-tables.html.twig',[
'users' => $users,
'count' =>$count,
]
);
}
<!-- recherche.html.twig -->
<form action="{{ path('recherche_client') }}" method="post">
{{ form_widget(form.rechercheClient, { 'attr': { 'class' : "form-control",'placeholder': "Rechercher par ID, nom , prénom, mail ou société"} }) }}
{{ form_widget(form) }}
</form>
<!-- data-table.html.twig -->
<div class="" style="float:right">
{{ knp_pagination_render(users) }}
</div>
public function recherche($chaine) {
return $this->createQueryBuilder('u')
->andWhere('u.nom like :chaine')
->orWhere('u.prenom like :chaine')
->orWhere('u.email like :chaine')
->orWhere('u.societe like :chaine')
->orderBy('u.id')
->setParameter('chaine','%'.$chaine.'%')
->getQuery()
->getResult();
}
答案 0 :(得分:0)
Amigo我遇到了同样的问题,但是由于我们对代码的理解不同,所以我将展示我的示例。
$searchForm = $this->createFormBuilder($property)
->add('type', EntityType::class, [
'class' => Type::class,
'choice_label' => 'name',
'mapped' => false,
'expanded' => true,
'multiple' => true,
'label' => false,
])
->add('filter', SubmitType::class, [
'attr' => [
'class' => 'btn btn-outline-dark btn-rounded waves-effect'
]
])
->setMethod('GET')
->getForm();
->setMethod('GET')
有所作为