我的常见问题系统运行良好,但我想在Select2中加入搜索功能。
到目前为止我得到了什么:
Select2 AJAX脚本
<script>
$("#searchall").select2({
ajax: {
url: "/ajax/searchallSelect2",
dataType: 'json',
delay: 250,
data: function (params) {
return {
q: params.term, // search term
page: params.page
};
},
processResults: function (data, params) {
// parse the results into the format expected by Select2
// since we are using custom formatting functions we do not need to
// alter the remote JSON data, except to indicate that infinite
// scrolling can be used
params.page = params.page || 1;
return {
results: data.items,
pagination: {
more: (params.page * 30) < data.total_count
}
};
},
cache: true
},
escapeMarkup: function (markup) { return markup; }, // let our custom formatter work
minimumInputLength: 1,
});
AjaxController.php
/**
* @Route("/ajax/searchallSelect2", name="ajax_searchall_select2")
*/
public function searchallSelect2Action(Request $request)
{
dump($request);
exit;
return $this->render('', array('name' => $name));
}
在&#34; index.html.twig&#34;
中选择2表单 <select id='searchall' style="width: 300px">
</select>
输入select2搜索字段后Firebug控制台输出:
GET http://localhost:8000/ajax/searchallSelect2?q=test 200 OK 16ms
我的问题是,如何实现数据库搜索?只需在AjaxController中使用getRepository吗?
$allfaqs = $this->getDoctrine()
->getRepository('AppBundle:Faq')
->findAll();
或者我是否需要在Ajax脚本中搜索数据库?
非常感谢任何帮助,谢谢您的阅读!
答案 0 :(得分:0)
您可以在控制器或queryBuilder
(推荐)中编写repository
并在控制器中调用它。您不应该在存储库中调用->findAll()
,因为它会获取您不需要的所有数据。您需要根据来自ajax的请求查询参数(即?q=test
)过滤数据。以下是Controller的代码段。
在你的控制器中:
/**
* @Route("/ajax/searchallSelect2", name="ajax_searchall_select2")
*/
public function searchallSelect2Action(Request $request)
{
$key = $request->query->get('q');
// Find rows matching with keyword $key..
$allfaqs = $this->getDoctrine()
->getRepository('AppBundle:Faq')->filterByKey($key);
// customize your output as per Select2 requirement..
return new JsonResponse($allfaqs);
}
在您的知识库中(考虑您在常见问题解答中搜索'name'属性。)
/**
* @param string $key
*
* @return type
*/
public function filterByKey($key)
{
$qb = $this->createQueryBuilder('faq')
->andWhere('faq.name LIKE :key')
->setParameter('key', '%' . $key . '%')
->getQuery();
return $qb->getQuery()->execute();
}
希望它有所帮助!让我知道你的担忧。
答案 1 :(得分:0)
谢谢,我在10分钟前解决了,但感谢您的帮助。
我的Select2现在正在搜索FAQ问题,答案以及与Faq(ManyToMany)链接的标签。
运作良好。
也许有人需要这个:
/**
* @Route("/ajax/searchallSelect2", name="ajax_searchall_select2")
*/
public function searchallSelect2Action(Request $request)
{
$em = $this->getDoctrine()->getManager();
$query = $em->createQuery(
'SELECT c
FROM AppBundle:Faq c WHERE c.question LIKE \'%'.$request->get('q').'%\' OR c.answer LIKE \'%'.$request->get('q').'%\'');
$query2 = $em->createQuery(
'SELECT c
FROM AppBundle:Tag c WHERE c.name LIKE \'%'.$request->get('q').'%\'');
$faqs = $query->getResult();
$tmpTags = $query2->getResult();
$returnArray = [];
$tmpReturns = array();
foreach($faqs as $faq) {
$tmpReturns[$faq->getId()] = $faq;
}
foreach($tmpTags as $tmpTag) {
foreach($tmpTag->getFaqs() as $tmpFaq) {
if(!isset($tmpReturns[$tmpFaq->getId()])) {
$tmpReturns[$tmpFaq->getId()] = $tmpFaq;
}
}
}
foreach ($tmpReturns as $faq)
{
/** @var $faq Faq */
$tags = array();
foreach($faq->getTags() as $tag) {
/** @var $tag Tag */
$tags[] = $tag->getName();
}
$returnArray[] = array(
'id' => $faq->getId(),
'text' => 'Titel => '. $faq->getQuestion(). ' '
. 'Inhalt: '. $faq->getAnswer(). ' '
. '('.implode(', ', $tags).')'
);
}
return new JsonResponse($returnArray);
}