2

我是第一次尝试 Backbone.js。我对 Django 并不陌生,因此我正在尝试为 Django 应用程序构建一个由 Backbone 驱动的前端。经过一番研究,我认为 Tastypie 可能是最容易上手的。

经过多次争论,我遇到了这个问题:我可以很好地创建对象,但我无法获取它们中的任何一个。

所以我可以这样做:

var foo = new LabSite()
var newInfo={name:"Mine",site_code:"FRED"}
foo.save(newInfo)

我可以在管理员中看到一个名为“Mine”的新 LabSite,其 ID 为 1。

当我尝试这个时:

var bar = new LabSite({id:1})

bar.fetch({
    success: function (bar) {
        alert(bar.toJSON());
    }
})

我没有看到警报。

在返回的对象上,它具有以下响应:

responseText: "callback({"id": "1", "name": "Mine", "resource_uri": "/api/v1/labsite/1/","site_code": "FRED"})"

所以它被退回了,价值不存在。也许有些东西不理解响应?

我尝试使用这个主干-tastypie 项目,但它没有改变任何东西: https ://github.com/amccloud/backbone-tastypie

我的 ModelResource 很简单:

class LabSiteResource(ModelResource):

    def determine_format(self, request):
       return  'text/javascript'

    class Meta:
       queryset = LabSite.objects.all()
       authorization= Authorization()

如果我去,http://localhost:8000/api/v1/labsite/1/我会看到:

   callback({"id": "1", "name": "Mine", "resource_uri": "/api/v1/labsite/1/", "site_code": "FRED"})

知道为什么我什么都拿不到吗?

编辑根据下面的评论,我试图抓住错误。

  var errorInfo = {};
  var bar = new LabSite({id:1})
  bar.fetch({
      success: function (bar) {
        alert(bar.toJSON());
      },
  error: function(a1,a2,a3) {
      errorInfo=[a1,a2,a3]

   }
   });

errorInfo没有提供很多有用的信息——它是这样的:

    > errorInfo[0]
    d
    _escapedAttributes: Object
    _pending: Object
    _previousAttributes: Object
    _silent: Object
    attributes: Object
    changed: Object
    cid: "c1"
    id: 1
    __proto__: x
    > errorInfo[1]
    [...]
    readyState: 4
    responseText: "callback({"id": "1", "name": "Mine", "resource_uri": "/api/v1/labsite/1/", "site_code": "FRED"})"
    setRequestHeader: function (a,b){if(!v){var c=a.toLowerCase();a=u[c]=u[c]||a,t[a]=b}return this}
    state: function (){return c}
    status: 200
    statusCode: function (a){if(a){var b;if(v<2)for(b in a)r[b]=[r[b],a[b]];else b=a[x.status],x.always(b)}return this}
    statusText: "OK"
    [....]
    > errorInfo[2]
    Object
    error: function (d,e){e=d===b?e:d;a?a(b,e,c):b.trigger("error",b,e,c)}
    success: function (d,e,f){if(!b.set(b.parse(d,f),a))return!1;c&&c(b,d)}
    __proto__: Object

errorInfo[1].status似乎表明通信已完全找到并且errorInfo[1].responseText是正确的数据。我现在可能比以前更困惑。

4

1 回答 1

1

您的 fetch 响应 JSON 包装到callback函数中。是jsonp吗?Backbone 需要纯 JSON。

于 2012-10-24T15:30:59.697 回答