国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Django 使用Ajax進行前后臺交互的示例講解

2020-02-15 21:33:00
字體:
來源:轉載
供稿:網友

本文要實現(xiàn)的功能是:根據下拉列表的選項將數據庫中對應的內容顯示在頁面,選定要排除的選項后,提交剩余的選項到數據庫。

為了方便前后臺交互,利用了Ajax的GET和POST方法分別進行數據的獲取和提交。

代碼如下:

<!--利用獲取的數據進行表單內容的填充--><script>$("#soft_id").change(function(){var softtype=$("#soft_id").find("option:selected").text();var soft={'type_id':softtype}$.ajax( { type: 'GET', url:'/data/soft-filter/{{family}}', dataType: 'json', data:soft, success: function( data_get ){ build_dropdown( data_get, $( '#min_version' ), '請選擇最低版本' );//填充表單 build_dropdown( data_get, $( '#max_version' ), '請選擇最高版本' ); build_div(data_get,$('#soft_affected')); } });  }); var build_dropdown = function( data, element, defaultText ){ element.empty().append( '<option value="">' + defaultText + '</option>' ); if( data ){ $.each( data, function( key, value ){ element.append( '<option value="' + key + '">' + value + '</option>' ); } ); } } var build_div = function( data, element){ if( data ){ element.empty(); $.each( data, function( key, value ){  element.append(' <li class="clearfix"> <div class="todo-check pull-left"><input name="chk" type="checkbox" value="'+value+'" /></div> <div class="todo-title">'+value+' </div><div class="todo-actions pull-right clearfix"><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="todo-complete"><i class="fa fa-check"></i></a><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="todo-edit"><i class="fa fa-edit"></i></a><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="todo-remove"><i class="fa fa-trash-o"></i></a></div> </li>'); } ); }}</script>
<!--選擇并提交數據--><script>//選擇數據function postselect (){  var seleitem=new Array(); $("input[name='chk']").each(function(i){ if(!($(this).is( ":checked" )) ){  seleitem[i]=$(this).val();  // alert(seleitem[i]); }});//將排除后的數據提交到后臺數據庫var soft={'type_id':seleitem}$.ajax( { type: 'POST', url:'/data/soft-submit', dataType: 'json', data:soft, success: function( data_get ){ } });}</script>

部分html代碼為:

 <div style="overflow: hidden;" >      <ul id='soft_affected' class="todo-list sortable">      </ul> </div>

views.py中處理請求和響應代碼:

def soft_submit(request): if request.is_ajax():  id=request.POST.get('type_id') return HttpResponse("success")def soft_filter(request,fami): softtype='' ajax_release_version=[] release_version=[] if request.is_ajax():  softtype=request.GET.get('type_id')  soft_type=SoftTypeRef.objects.using('vul').filter(description=softtype)  soft_tp_id=0  for i in soft_type:   soft_tp_id= i.soft_type_id  web_soft=SoftWeb.objects.using('vul').filter(soft_type_id=soft_tp_id)  for i in web_soft:   ajax_release_ver=i.release_version   ajax_release_version.append(ajax_release_ver)  return HttpResponse(json.dumps(ajax_release_version), content_type='application/json')            
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 鲁甸县| 松原市| 平和县| 天台县| 方山县| 桂东县| 章丘市| 九寨沟县| 武安市| 顺平县| 宿州市| 金溪县| 海伦市| 玉田县| 新野县| 庆云县| 肇东市| 辉南县| 酒泉市| 贵州省| 余干县| 鲜城| 凤冈县| 天全县| 长兴县| 卢氏县| 淮滨县| 双桥区| 曲麻莱县| 西畴县| 宣汉县| 石阡县| 闸北区| 金塔县| 绥化市| 水富县| 道孚县| 塔河县| 修水县| 濉溪县| 孝感市|