从js发送复选框数组到Django视图

时间:2019-04-29 12:57:06

标签: python arrays json ajax django

我对如何通过Ajax或Json进行操作感到困惑,但是如何将选择数组(curCheck)单击发送到Django视图并将其作为python数组接收

javascript

document.getElementById('results').addEventListener('click', function(){
    html_table = '<thead><tr><th>Currency</th><th>Amount</th><th>Symbol</th>><tr/><thead/>'
        var checkElements = document.getElementsByClassName('ch');
        for(var i =0; i< curname.length; i++){
            if (checkElements[i].checked) {
            var curChecked = curname[i];
            var JsonArr = JSON.stringify(curChecked);
            postcurChecked(JsonArr)
            html_table += '<tr><td>' + curname[i] + '</td>';
            }
}
document.getElementById('result_table').innerHTML = html_table;
},false;

ajax

function postsubChecked(curChecked) {
    $.ajax({
        "url": "http://127.0.0.1:8000/results/",
        "type": "POST",
        "data": {"checkbox": curChecked},
        "headers": { 'X-CSRFToken': getCookie('csrftoken')}
    })
}

在Django

def currencyChecked(request): 
    body_unicode = request.body.decode('utf-8') 
    body_unicode = body_unicode.replace('%22','') 
    print(body_unicode) json_data = json.loads(body_unicode.read())

我想看一下python数组的打印内容,看看它是否传递到了后面

但我不断收到此错误: json_data = json.loads(body_unicode.read())AttributeError:'str'对象没有属性'read'

1 个答案:

答案 0 :(得分:1)

要获取选定的复选框值并使用ajax作为数组发送,可以使用如下的jquery:

请考虑您有多个复选框和一个按钮。

<input type="checkbox" name="imageName">
<input type="checkbox" name="imageName">
.......
<button id="deletePhoto">Delete</button>

选择多个复选框值后,单击此按钮。点击下面的jquery会触发以选中的复选框值作为对象。

//jquery for getting the selelcted checkbox values 

  $(document).on("click","#deletePhoto",function(){

    var favorite = [];//define array

    $.each($("input[name='imageName']:checked"), function(){            
        favorite.push($(this).val());
    });

    alert("Photo Selected: " + favorite.join(", "));

    if(favorite.length == 0){
      alert("Select Photo to delete");
      return false;
    }

    //ajax for deleting the multiple selelcted photos
    $.ajax({type: "GET",
    url: "/olx/deletePhotoFromEdit",
    data:{
      favorite:favorite
    },
    success: function(){
     // put more stuff here as per your requirement
    });

   }
    });

});

在视图中,您可以像这样获得数组:

selected_photo = request.GET.getlist('favorite[]')