jQuery POST没有返回变量用户

时间:2013-08-04 14:01:58

标签: jquery django jquery-post

我正在尝试发布复选框的值,但无法这样做。它首先收集一个数组中的所有复选框(selected_users - 在使用alert函数测试它时工作正常),然后集体发送它们。但是我无法发布数据。我得到的错误是找不到密钥'用户'。哪里出错了?如何在jQuery插件中修改我的POST语句?

View.py

def get_data(请求):

if request.method == 'POST': 
    selected_users = request.POST['users']
return HttpResponse(selected_users)

urls.py

urlpatterns = patterns('',
    url(r'get_data/','apps.api.views.get_data', name = 'grabhalo_get_data'),
)

的jQuery

$(document).ready(function(){
                $('#submit').click(function() {
                  var selected_users = $('input[type=checkbox]:checked').map(function(_, el) {
                    return $(el).val();
                    }).get();
                    alert(selected_users);     // works fine
                    $.post("get_data/",{users:selected_users});   // not able to post
                });    
            })

复选框

{% for user in users %}
    <input type="checkbox" class="check" value="{{user.id}}" />{{user.name}}<br>    
{%endfor%}

    <form id="form" method="POST" action="/get_data/">
       {% csrf_token %}
       <input type="text" class="span8 search-query" placeholder="Type here..." name="chat">
       <input type="submit" value="Send" class = "btn btn-primary" id = "submit">
   </form>

如果有人可以重新定义.post功能,欢迎不同的建议。

谢谢

4 个答案:

答案 0 :(得分:0)

为什么不尝试这样的POST:

$(document).ready(function(){
  $('#submit').click(function() {
      var selected_users=[];
      var $inputs = $('.check');
      $inputs.each(function() {         
            selected_users.push( $(this).val());        
        });            
                    alert(selected_users);     // works fine
      $.post("get_data/",{"users" : selected_users},function(response) 
        {
            alert(response);
        });     
            })

在你的view.py中试试这个:

if request.method == 'POST': 
selected_users = request.POST.get("selected_users", "")
return HttpResponse(selected_users)

答案 1 :(得分:0)

您的JQuery $ .post函数没问题,问题是在Django视图中获取值。您正在发布一组值 - 为了让它们在POST QueryDict上使用getlist()函数。所以你的观点看起来像这样:

if request.method == 'POST':
    selected_users = request.POST.getlist('users[]')
    return HttpResponse(selected_users)

请参阅:

QueryDict.getlist(key, default)

django - getlist()

答案 2 :(得分:0)

你必须将@Aditya和@Yurly的答案结合起来:

<强>脚本

function get_csrf_token(){
    return $("input[name='csrfmiddlewaretoken']").val();
}

$(document).ready(function(){
    $('#submit').click(function() {
        var datas = new Array();
        var i = 0;
        var csrf_token = get_csrf_token();

        $("input[type=checkbox]:checked").each(function() {
            datas[i] = $(this).val();
            i++;
        });   

        #make sure the url is correct
        $.post("get_data/", {'users[]': datas, 'csrfmiddlewaretoken': csrf_token}, function(data){
            alert(data);
        });   
    });    
})

<强> views.py

if request.method == 'POST':
    selected_users = request.POST.getlist('users[]')
    return HttpResponse(selected_users)

答案 3 :(得分:0)

提交表单时,您需要阻止默认操作。否则,您的页面会刷新,从而无法发布帖子。

还使用serialize数组将它们转换为数组。试试这个

$(document).ready(function(){
     $('#submit').click(function(e) {
         e.preventDefault();
         // Will only serialize the checked values by default
         var selected_users = $('input[type=checkbox]').serializeArray();
          console.log(selected_users);     
          $.post("get_data/",{'users[]':selected_users}); 
     });    
})

如果您想使用更多选项,可以使用$.ajax

$.ajax({
     url : 'get_data', 
     data : {'users[]' : selected_users},
     dataType: "set it to the type you are expecting".
     type : 'post'
}).done(function(data, status, xhr) {
   console.log(data)
}).fail(function(xhr, status, error) {
   console.log("Error status : "+ status + "-- error : " + error);
});