最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小采 时间:2020-11-27 22:10:15
文档

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

bootstrap select2插件用ajax来获取和显示数据的实例:用select2插件,实现以下这个选择框: 1、html代码 <div class=form-group style='display:none;' id='preParamGroup'> <label for=inputEmail3 class=col-sm-2 control-label>预定义参
推荐度:
导读bootstrap select2插件用ajax来获取和显示数据的实例:用select2插件,实现以下这个选择框: 1、html代码 <div class=form-group style='display:none;' id='preParamGroup'> <label for=inputEmail3 class=col-sm-2 control-label>预定义参


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

文档

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

bootstrap select2插件用ajax来获取和显示数据的实例:用select2插件,实现以下这个选择框: 1、html代码 <div class=form-group style='display:none;' id='preParamGroup'> <label for=inputEmail3 class=col-sm-2 control-label>预定义参
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top