- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我成功地从我创建的 API 中加载并显示了与“Backbone Relational”的关系。我通过反复试验了解事情的运作方式。我确实认为文档不够清晰,因为花了很多时间来弄清楚事情是如何工作的。尤其是关于如何将事物映射到 API,我认为文档有点欠缺。
问题
添加书签有效,编辑和删除无效。 PUT 变成了 POST,而 DELETE 根本就不会触发。当我将 id
设置为硬编码的模型时,它确实有效。因此缺少 id
,这对于 PUT 成为 POST 是有意义的。
问题似乎是 id
没有实际的 id
,而是一个集合。出现问题的 View 不需要 BookmarkBinding,它在其他地方使用。仅仅因为它具有 Bookmark 作为关系,所以 DELETE 和 PUT 中断。
书签绑定(bind)模型:
App.Model.BookmarkBinding = Backbone.RelationalModel.extend({
defaults: {
set_id: null,
bookmark_id: null
},
relations: [{
type: Backbone.HasOne,
key: 'bookmark',
relatedModel: 'App.Model.Bookmark',
reverseRelation: {
type: Backbone.HasOne,
key: 'id'
}
}],
urlRoot: 'http://api.testapi.com/api/v1/bookmark-bindings'
});
书签模型:
App.Model.Bookmark = Backbone.RelationalModel.extend({
defaults: {
url: 'undefined',
description: 'undefined',
visits: 0,
},
relations: [{
type: Backbone.HasMany,
key: 'termbindings',
relatedModel: 'App.Model.TermBinding',
reverseRelation: {
key: 'bookmark_id',
}
}],
urlRoot: 'http://api.testapi.com/api/v1/bookmarks'
});
最佳答案
The default sync handler maps CRUD to RESTful HTTP methods like so:
create → POST /collection
read → GET /collection[/id]
update → PUT /collection/id
delete → DELETE /collection/id
您的问题表明您正在发出 HTTP PUT 请求,因此是 Backbone 更新。如果要进行 HTTP POST,请使用 Backbone create。 PUT 请求映射到更新,并要求在 URL 中发送一个 id,根据您的服务器日志,这不会发生。如果您要创建一个新对象,那么大多数服务器端框架(例如 Rails/Sinatra/Zend)都会为该对象创建一个 id
另一个可能的错误来源是您为关系选择的键,就像您怀疑的那样。
一个 Bookmark 有很多 BookmarkBindings,似乎 Backbone-relational 会将它们存储在您在 BookmarkBindings.relations.reverseRelation.key 中指定的字段中,该字段当前定义为“id”。因此,相关 BookmarkBindings id 的集合将存储在与 Bookmark.id 相同的属性上,从而产生冲突。 Backbone.sync 将向服务器发送一个未定义的值(您在日志中看到),因为它在那里找到一个集合而不是一个整数。
第一个建议 - 您可能不需要双向关系,在这种情况下将其从 BookmarkBinding 模型中删除。
第二个建议 - 在另一个键上定义反向关系,这样它就不会与 Bookmark.id 冲突,例如 BookmarkBindings.relations.reversRelation.key : 'binding_ids'
关于javascript - 'Backbone Relational' 模型关系添加一个 'id' 和一个集合作为值,防止 PUT 和 DELETE,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24021082/
我正在处理批处理作业,以通过 HTableInterface 将一批 Put 对象处理到 HBase 中。有两个 API 方法,HTableInterface.put(List) 和 HTableIn
我想转置curl命令(将本地文件上传到机架空间) curl -X PUT -T screenies/hello.jpg -D - \ -H "X-Auth-Token: fc81aaa6-98a1-9
我认为执行 puts #{a} 会产生与 puts a 相同的输出,但发现情况并非如此。考虑: irb(main):001:0> a = [1,2] => [1, 2] irb(main):002:0
我尝试在我的一个移动应用程序中使用这个cordova后台服务插件(我正在使用名为Appery io的基于网络的移动应用程序开发平台)。我已经能够让相当多的 cordova/phonegap 插件正常工
传奇有多个 put。 export function* changeItemsSaga(action) { const prerequisite1 = yield select(prerequ
我正在从工作正常的 jquery $.ajax 切换到使用 AngularJS $http.put 来访问 Restful API。 我可以进行 API 调用,但 PUT 数据未发送 - 因此我的 A
我的 express 里有这个 router.put('/admin/profile?:id/actions', (req, res) => { console.log(req.body.action
我正在浏览 Ruby tutorial , 并了解到代码 puts 'start' puts puts 'end' 会输出三行,但是下面的代码 puts 'start' puts [] puts 'e
我的目标是使用 TreeMap 使 Box 键对象按 Box.volume 属性排序,同时能够将键按 Box.code 区分。在 TreeMap 中不可以吗? 根据下面的测试 1,HashMap pu
我一直在尝试使用HBase客户端库将记录列表插入HBase。 它适用于Table或HTable中的单个Put(不建议使用),但不能识别List(Puts) 错误说:预期:util.List,但是Lis
我正在使用 Google-guava-cache。将其定义为: Cache myCache= CacheBuilder.newBuilder().maximumSize(100).build();
我只是想知道threadContext.put和MDC.put之间的区别。因为,我相信两者都在做相同的操作。 最佳答案 Log4j 2 continues with the idea of the M
我的 GAE 应用程序上有一些模型,并且我已覆盖 put()关于其中一些。当我调用db.put()时有了这些实体的列表,是否可以保证覆盖 put()每个实体都会被调用? 我现在看到的是实体只是被保存而
module Lab def self.foo puts 'foo from lab' end end module M def foo puts 'foo from mo
我正在查看示例 abo3.c来自 Insecure Programming我并没有在下面的例子中摸索类型转换。有人可以启发我吗? int main(int argv,char **argc) {
我正在 symfony2.4 和 angularjs 中构建应用程序。在 Angular 中我创建了资源: app.factory('Tasks', ['$resource', function($r
到处都说[看了很多帖子] PUT 是幂等的,意味着具有相同输入的多个请求将产生与第一个请求相同的结果。 但是,如果我们使用 POST 方法发出具有相同输入的相同请求,那么它又将表现为 PUT。 那么,
这里是WebApiConfig.cs中的路由配置: config.Routes.MapHttpRoute( name: "DefaultApiPut", routeTemplate:
这两种方法有什么区别: getInputMap(JComponent.WHEN_FOCUSED).put(KeyStroke.getKeyStroke( "pressed F10"),
由于匿名 block 和散列 block 看起来大致相同。我正在玩它。我做了一些严肃的观察,如下所示: {}.class #=> Hash 好的,这很酷。空 block 被视为Hash。 print{
我是一名优秀的程序员,十分优秀!