Symfony2使用Select2和Ajax搜索数据库

时间:2016-09-25 16:30:58

标签: javascript php ajax symfony doctrine

我的常见问题系统运行良好,但我想在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脚本中搜索数据库?

非常感谢任何帮助,谢谢您的阅读!

2 个答案:

答案 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);
}