Select2,Symfony:自动完成,远程数据不起作用

时间:2017-12-17 15:30:21

标签: javascript symfony jquery-select2

我正在尝试在我的网站上搜索城市时实施自动填充搜索(拼车)。 我创建了一个控制器searchCity,它返回一个带有城市的json:

 /**
 * @Route ("/city/{term}")
 */
public function searchCity($term)
{
    $query = $this->getDoctrine()->getRepository('App:Ville')
        ->createQueryBuilder('v')
        ->select('v.id, v.nomReel AS text')
        ->where('v.nomSimple LIKE :term')
        ->setParameter('term', $term.'%')
        ->getQuery()
        ->getResult();

    $query = array('results' => $query);
    return new JsonResponse($query);
}

例如,如果我去/ city / Paris,我会得到:

    {"results":[
        {"id":30438,"text":"Paris"},
        {"id":29427,"text":"Paris-l\u0027H\u00f4pital"}, //I know single quotes
        {"id":33294,"text":"Parisot"},                   //don't work
        {"id":33531,"text":"Parisot"}]}

选择:

<div class="container">
    <select id="citySelect" class="select2 select2-dropdown select2-search" name="term">
    </select>
</div>

javascript:

        $(document).ready(function(){
            $("#citySelect").select2({
                placeholder: "Select city",
                ajax: {
                    dataType: "json",
                    url: function (params) {
                        return '/city/' + params.term;
                    },
                    processResults: function (data) {
                        return {
                            results: $.map(data, function(obj) {
                                return { id: obj.ime, text: obj.ime };
                            })
                        };
                    }
                }
            });
        });

当我搜索一个城市时,没有任何东西显示出来(搜索......什么都没有) 使用控制台日志我可以看到数据存在并且格式良好但是城市没有显示在下拉菜单中。 我认为我的问题在于我的javascript代码和我对select2的理解。

此致

更新:

js:

            $(document).ready(function(){
            $(".select2").select2({
                placeholder: "Select city",
                ajax: {
                    dataType: "json",
                    url: function (params) {
                        return '/city/' + params.term;
                    },
                    processResults: function (data) {
                        return {
                            results: data.results //return data directly
                        };
                    }
                }
            });
        });

1 个答案:

答案 0 :(得分:0)

我想在转换你想要的数据时

SUM()

而不是

DELETE

另外看你发布的json你可能(未经测试)只做

INSERT