使用AJAX解析Django QuerySet



我返回一个QuerySet为1,我的JQuery看起来像这样

<script> 
    $(document).ready(function(){
    $("#search_form").submit(function(event)
    {
        event.preventDefault();
        $.ajax({
            type: "POST",
            url: "object/search/",
            processData: false,
            dataType: "json",
            success: function(data){
                $.each(data, function(key, value){
                    alert( key + ': ' + value );
                    });
                }
            });
    });});
</script>

警报将显示,但它返回0:[object object]。我想显示返回的Object模型的name属性。比如使用object。name。我真的被卡住了,非常感谢你帮我解决这个问题。

我的视图代码是:

if request.is_ajax():
    if request.method == 'POST':
        format = 'json'
        mimetype = 'application/json'
        o = Object.objects.filter(name__icontains="bin")
        data = serializers.serialize(format, o)
        return HttpResponse(data, mimetype)     

我只返回1对象与此查询,但它的类型是QuerySet。

编辑。下面是数据返回时的样子:

>>> o
[<Object: Bin Ber>]
>>> data = serializers.serialize(format, o)
>>> data
'[{"pk": 1, "model": "objects.object", "fields": {"name": "Bin Ber", "roof": 3,                                               "depth": [3], "user": 1, "created_when": "2011-08-16 03:11:36", "shared": false,                                                          "projects": [1], "description": null}}]'

根据您的编辑:

$.each(data, function(key, value){
        alert( key + ': ' + value.fields.name );
    });
}

查看返回的数据只需使用javascript函数JSON.stringfy(data);它应该显示数据而不是[object object]

相关内容

  • 没有找到相关文章

最新更新