2

我有一个视图页面,目前显示了两列数据,很快将扩展到四列。每列包含该特定模型的 QuerySet 的结果。

这是我的 views.py 方法中的内容:

if request.REQUEST["type"] == "text":
        client = Client.objects.get(client_name = request.REQUEST["search"])
        peerList = ClientPeers.objects.prefetch_related().filter(client = client.client)
        compList = ClientCompetitors.objects.prefetch_related().filter(client = client.client)

else:
    peerList = ClientPeers.objects.prefetch_related().filter(client = request.REQUEST["search"])
    compList = ClientCompetitors.objects.prefetch_related().filter(client = request.REQUEST["search"])

for peer in peerList:
    peerlst.append({"pid" : peer.parentorg.parentorg, "pname" : peer.parentorg.parentorgname})

for comp in compList:
    complst.append({"cid" : comp.parentorg.parentorg, "cname" : comp.parentorg.parentorgname})

lst.append(simplejson.dumps(peerlst))
lst.append(simplejson.dumps(complst))

return HttpResponse(simplejson.dumps(lst), mimetype = "text/json")

这允许我以格式将二维数据数组发送到浏览器

[ { //JSON }, { //JSON } ]

在我的 jQuery.ajax 成功函数中,我有

function handler(results) {
  var data = JSON.parse(results);

  for (var i = 0; i < data[0].length; i++)
    $("#available_peers").append("<li>" + data[0][i].pname + "</li>");

  for (var i = 0; i < data[1].length; i++)
    $("#available_competitors").append("<li>" + data[1][i].cname + "</li>");

Firebug 显示 GET 请求有效,我可以在响应选项卡中看到数据。但是,控制台打印出来

SyntaxError: JSON.parse: unexpected non-whitespace character after JSON data
var data = JSON.parse(results)

如果我替换var data = JSON.parse(results)

var peers = JSON.parse(data[0]);
var comps = JSON.parse(data[1]);

为什么一种方法有效而另一种方法无效?

4

1 回答 1

1

jQuery ajax()调用将对返回的数据类型进行智能猜测。在您的示例中function handler(results),该results变量已经是一个解码的 JSON 对象,在一个数组中包含两个项目。有效的原因JSON.parse(data[0])是您已将 JSON 编码数据作为字符串返回。

在放入输出数组之前,不要将单个列表元素编码为 JSON:

lst.append(peerlst)  # <-- Don't encode to JSON string here
lst.append(complst)

return HttpResponse(simplejson.dumps(lst), mimetype = "application/json") # <-- Single JSON encoding
于 2013-06-27T09:35:01.707 回答