当前位置: 移动技术网 > IT编程>开发语言>JavaScript > bootstrap select2插件用ajax来获取和显示数据的实例

bootstrap select2插件用ajax来获取和显示数据的实例

2019年06月04日  | 移动技术网IT编程  | 我要评论

用select2插件,实现以下这个选择框:

1、html代码

<div class="form-group" style='display:none;' id='preparamgroup'>
	<label for="inputemail3" class="col-sm-2 control-label">预定义参数</label>
	<div class="col-sm-8">
		<select class="js-states form-control" id="preparamdefine" multiple="multiple" style="width: 100%"></select>
	</div>
</div>

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来获取和显示数据的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持移动技术网。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网