2、js代码


$("#preParamDefine").select2({
 //data: data,
	placeholder:'请选择',//默认文字提示
	tags: true,//允许手动添加
 allowClear: true,//允许清空 
	ajax: {
 url: '/jgwork/param_select',
 type:'GET',
 dataType: 'json',
 data: function(){ return {'projectId':$('#projectSel').val()}},
 processResults: function (data) {
 return {
 results: data.result
 };
 }
 }
 
})

用ajax从服务端获取数据,在processResult里来返回数据

3、服务端代码

服务端返回的数据格式如下:


data = [
{ 'text': 'enhancement' ,
 'children':[
 { 'id': 1, 'text': 'bug','parent':'enhancement' }, 
 { 'id': 2, 'text': 'duplicate' ,'parent':'enhancement'},
 { 'id': 3, 'text': 'invalid' ,'parent':'enhancement'},
 { 'id': 4, 'text': 'wontfix' ,'parent':'enhancement'}
 ]
}
]

代码:


proId = request.GET.get('projectId','')
paramList = [param.show_table() for param in paramDefine.objects.filter(proid = proId)]
data = []
index = 1
for item in paramList:
	childList = []
	for i in item['paramValue'].split(','):
 childList.append({
 'id': index,
 'text': i,
 'param': item['paramName']
 }) #生成children字段列表
 index += 1
	data.append({
 'text': item['paramName'],
 'children': childList
 })
return JsonResponse({'result':data})

这里注意,index不能从0开始,不然生成的id有一个为0,会导致这个选项无法选取,因为在select2中id=0有特殊意义

以上这篇bootstrap select2插件用ajax来获取和显示数据的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

bootstrap select2 ajax
文章分类
相关文章