如何在django视图中从ajax获取和访问JSON数据?

时间:2015-11-07 03:33:26

标签: json ajax django django-views

我正在尝试使用对视图的ajax调用从我的模板发送动态创建的JSON数据。我能够通过ajax调用生成并传递JSON数据,但无法在视图中读取相同内容。我阅读了很多关于此的文章和stackoverflow帖子,但没有为这个简单的任务工作。下面是我的Ajax调用:

API

在上面给出的代码中,您可以忽略for循环部分,因为它只是遍历某些包并检查该页面上的用户选择了哪个包,并相应地生成要作为JSON对象传递的字典。此外,我检查了mystring变量中生成的数据(使用alert(mystring);),然后将其发送到视图并且它具有所需的数据。

以下是我的观点代码:

$(document).ready(function() {
    $('#applybtn').click(function(){
        var selectedpackages = [];
        {% for package in packages %}
            if($("input[name=package{{forloop.counter}}]").is(':checked')){
                type = $("input[name=package{{forloop.counter}}]:checked").attr('id');
                var Obj = {}
                Obj['pkgid'] = {{package.id}};
                Obj['type'] = type;
                selectedpackages.push(Obj);
            }
        {% endfor %}
        var mystring = JSON.stringify(selectedpackages);
        $.ajax({
            url:"/ApplyCode/",
            type:"GET",
            data:mystring,
            dataType: "json",
            contentType: "application/json",
            success: function(data){
                alert(data);
            }
        });    
    });
});

我确信在“selectedpackages”变量中获取JSON数据时,我遗漏了一些东西。我尝试了很多其他方法,但没有任何效果。在这里,我只想获取数据,而不是想访问相同的每个元素。任何帮助表示赞赏。

1 个答案:

答案 0 :(得分:5)

如果您执行request.body请求,

GET将不会包含任何内容,这会将所有内容放入网址中。您需要更改AJAX调用以执行POST

$.ajax({
    // ...
    type:"POST",
    // ...
});

然后相应地修改您的视图代码:

if request.method == 'POST':
    selectedpackages = json.loads(request.body)