Tor*_*tar 5 javascript ajax jquery json jquery-select2
我正在使用带有远程ajax数据的select2插件.我可以在下拉列表中看到结果,但无法选择它们.我希望结果可以选择并在选择后放入字段中.我认为问题在于传递id,我不知道如何正确传递它.任何想法?
我的json for?tag_word = for ...没有id
results: [{text: "fort"}, {text: "food"}]
Run Code Online (Sandbox Code Playgroud)
这里的代码:
<select class="js-data-example-ajax" style="width:100%">
<option selected="selected">asdasd</option>
</select>
<link href="//cdnjs.cloudflare.com/ajax/libs/select2/4.0.0/css/select2.min.css" rel="stylesheet" />
<script type="text/javascript" src="{% static 'js/select2.js' %}"></script>
<script >
$(document).ready(function(){
$('.js-data-example-ajax').select2({
minimumInputLength: 2,
multiple:true,
delay: 250,
cache: true,
ajax: {
url: '/tags/search/autocomplete/',
dataType: 'json',
data: function (parms, page) { return { tag_word: parms.term }; },
},
});
});
</script>
Run Code Online (Sandbox Code Playgroud)
这是服务器代码:
def autocomplete(request):
s = SearchQuerySet(using='autocomplete')
sqs = s.autocomplete(content_auto=request.GET.get('tag_word'))[:5]
suggestions = [ {'text':result.tag_word,
'id':result.tag_word,} for result in sqs]
the_data = json.dumps({
'results': suggestions
})
return HttpResponse(the_data, content_type='application/json')
Run Code Online (Sandbox Code Playgroud)
要选择一个选项,每个结果都需要具有唯一ID.因此,您可以使用以下代码(processResults
)添加id .
$('.js-data-example-ajax').select2({
minimumInputLength: 2,
multiple:true,
delay: 250,
cache: true,
ajax: {
url: '/tags/search/autocomplete/',
dataType: 'json',
data: function (parms, page) { return { tag_word: parms.term }; },
processResults: function (data) {
data.results.forEach(function (entry, index) {
entry.id = ''+index; // Better if you can assign a unique value for every entry, something like UUID
});
return data;
},
cache: true
},
});
Run Code Online (Sandbox Code Playgroud)
这是一个快速破解。不知道你如何处理 select2 文档。但以下代码在我的本地主机中与我一起工作。
$(document).ready(function(){
$.get("json/select.json",function(data){ //specify your url for json call inside the quotes.
for(var i = 0; i < data.length; i++){
data[i]={id:i,text:data[i].text}
}
$(".js-data-example-ajax").select2({
minimumInputLength: 2,
multiple:true,
delay: 250,
data: data
})
});
}
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
7832 次 |
最近记录: |