質問

ここで回答したのと同じ問題があります。 typeahead.js

しかし、私は答えの回避策を使うことはできません。提案のリストが動的であるため! ユーザーに彼らのクエリで非ASCII文字(é、à、è、ëなど)を使う方法はありますか?

役に立ちましたか?

解決

これは見つかった解決策です:

HTML

$('.typeahead').typeahead(
        {
            minLength: 3,
        },
        {
            name: 'place',
            displayKey: 'city',
            source: function (query, process) {
                return $.get("{% url 'profil:search_place_request' search_term='user-query' %}".replace('user-query', query), { query: query }, function (data) { 
                    objects = [];
                    $.each(data, function(i, object) {
                        objects.push({
                            city : object.city,
                            zipcode : object.zipcode,
                            id : object.id,
                        });
                    });
                    return process(objects);
                });
            }
        }
    );
.

VIEW

@login_required
def search_place_request(request, search_term):
    search_term = search_term.encode("utf-8")
    response, response_dict = selfcare.libs.core.utils.MyAPIRequests.get("place/?term={}".format(search_term))
    if response.ok :
        log.info('[profil] request GET places. Search term : {},  USER : {}'.format(search_term, request.user.username))
        return HttpResponse(json.dumps(response_dict['results']), content_type="application/json") 
    else :
        log.warning('[profil] request DELETE customer address failed. Status code : {}, USER: {}'.format(response.status_code, request.user.username))
        return HttpResponse("", content_type="application/json") 
    return HttpResponse("", content_type="application/json")
.

私のビューでutf8で明示的にエンコードし、それはトリックをしました!

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top