1. 程式人生 > >Django中使用Ajax進行前後臺互動

Django中使用Ajax進行前後臺互動

本文要實現的功能是:根據下拉列表的選項將資料庫中對應的內容顯示在頁面,選定要排除的選項後,提交剩餘的選項到資料庫。為了方便前後臺互動,利用了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="#" class="todo-complete"><i class="fa fa-check"></i></a><a href="#" class="todo-edit"><i class="fa fa-edit"></i></a><a href="#" 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')

轉載請註明出處。歡迎關注本公眾號,檢視更多幹貨!
這裡寫圖片描述