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

本文介绍如何使用Select2插件结合Ajax技术实现动态加载数据的多级联动选择框,并允许用户手动输入。具体实现包括HTML结构搭建、JavaScript配置以及后端数据处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

用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有特殊意义




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值