Django 使用Ajax进行前后台交互的示例讲解

320人浏览 / 0人评论

本文要实现的功能是:根据下拉列表的选项将数据库中对应的内容显示在页面,选定要排除的选项后,提交剩余的选项到数据库。

为了方便前后台交互,利用了Ajax的GET和POST方法分别进行数据的获取和提交。

代码如下:



$("#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( '' + defaultText + '' );
 if( data ){
 $.each( data, function( key, value ){
 element.append( '' + value + '' );
 } );
 }
 }
 var build_div = function( data, element){
 if( data ){
 element.empty();
 $.each( data, function( key, value ){
  element.append(' 
  • '+value+'
  • '); } ); } }
    
    
    //选择数据
    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 ){
     }
     });
    }
    

    部分html代码为:

     

    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')

    以上这篇Django 使用Ajax进行前后台交互的示例讲解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

    全部评论

    晴天下起了小雨
    2017-10-01 18:00
    很喜欢,果断关注了
    wjmyly7336064
    2017-10-01 18:00
    相当实用,赞美了
    橘大佬
    2017-10-01 18:00
    就是有些细节再到位点就好了…