UTF-8でのtypeahead.jsユーザークエリ
-
21-12-2019 - |
質問
ここで回答したのと同じ問題があります。 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で明示的にエンコードし、それはトリックをしました!
所属していません StackOverflow