- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
Ember : 1.13.3
Ember Data : 1.13.5
jQuery : 1.11.3
我正在尝试使用 ember-data 将 JSON 有效负载从我的 EmberJS 客户端发送到我的服务器。我想在保存项目时将整个对象图发送到服务器,因为我不想发送多个请求。我不介意发送多个请求,但我担心如果其中一个请求中途失败,服务器上的数据将不正确,会发生什么情况。
我想使用 JSONAPI ( http://jsonapi.org/format/#document-compound-documents ),因为它正在成为 Ember 中的默认适配器。另外,有一些 C# 库可以处理这种格式,所以我认为这会非常简单。然而,在阅读规范后,如果对象没有 id,我似乎无法嵌入对象。即使我在 DS.attr 上指定了 { async: false,embedded: 'always' })
,EmberJS 也不会将子对象附加到 JSON。
我的问题是:如果应用程序的使用方式是在客户端创建对象图,那么如何使用 JSONAPI 格式将整个对象图发送到服务器?我是否必须在客户端生成 id 才能满足 JSONAPI 标准?然后,一旦它们到达服务器,就忽略它们,以便使用 ORM 生成的 id 保存它们?
这是我的 labelGroup 模型:
import DS from 'ember-data';
export default DS.Model.extend({
name: DS.attr('string'),
labels: DS.hasMany('label-model', { async: false, embedded: 'always' })
});
这是我的项目模型:
import DS from 'ember-data';
export default DS.Model.extend(DS.EmbeddedRecordsMixin, {
name: DS.attr('string'),
labelGroups: DS.hasMany('labelGroup', { async: false, embedded: 'always'})
});
这是我在项目上执行 save() 后得到的 POST:
{
"data":{
"attributes":{"name":"Project"},
"relationships":{
"label-groups":{
"data":[
{"type":"label-groups","id":null},
{"type":"label-groups","id":null},
{"type":"label-groups","id":null},
{"type":"label-groups","id":null},
{"type":"label-groups","id":null},
{"type":"label-groups","id":null},
{"type":"label-groups","id":null}
]
}
},
"type":"label-projects"
}
}
更新:我尝试使用 https://www.npmjs.com/package/ember-cli-uuid生成它所拥有的客户端 ID。然而,获取输出的数据不包括额外的对象,仅包括对其 id 的引用。我期望看到此处指定的“包含”属性:http://jsonapi.org/format/#document-compound-documents ,但它不存在。
{
"data":{
"id":"7b4544ee-91cd-493d-8b10-52040e68c283",
"attributes":{"name":"Project"},
"relationships":{
"label-groups":{
"data":[
{"type":"label-groups","id":"08115273-e82a-4d46-93ea-232ce071fb78"},
{"type":"label-groups","id":"9ca94fe9-8077-411e-98d2-1694c6fecce4"},
{"type":"label-groups","id":"d629f1e8-7962-404d-8034-38229ab21f77"},
{"type":"label-groups","id":"c6bda655-5489-4760-847b-bf02239bb2c5"},
{"type":"label-groups","id":"f6fef249-2d1d-43f0-ba64-24b7ff8b5637"},
{"type":"label-groups","id":"a7db25bf-52c8-477b-83e4-64e7c76b072e"},
{"type":"label-groups","id":"f3b5fbb3-261a-4b3d-b481-b9352f8ce2d6"}
]
}
},
"type":"label-projects"
}
}
最佳答案
Ember-data 目前不支持您想要的内容。因此 ember-data 不会将您的关系数据保存在保存负载中。
但是您可以通过使用自定义适配器和序列化器自己完成此操作。我强烈建议您查看API然后查看源代码。
如果您在模型上调用.save()
,则会在适配器上调用createRecord
方法。这里调用序列化器上的 serializeIntoHash
来序列化模型。
serializeIntoHash
调用 serialize
,其中调用 serializeBelongsTo
和 serializeHasMany
。
现在您只需覆盖 serializeHasMany
并修改该行之前的 hasMany
即可:
json[payloadKey] = hasMany;
这里有由 ember-data 发送的类型和 ID。您只需.forEach
hasMany 上的数据,然后获取数据的存储并构建您的included
数组。
我希望这可以帮助您了解序列化器和适配器,以便您可以轻松修改它以完成您想要的任何操作。实际上,这是 ember-data 最好的部分。适配器和序列化器的结构,允许轻松修改。
关于ember.js - EmberJS 在有效负载 JSONAPI 中嵌入了项目,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32364987/
随着从 SproutCore 2.0 到 EmberJS 的迁移,有命名空间和 Github 存储库迁移。核心的东西好像移到了http://github.com/emberjs组织 Github 帐户
我有一条使用 ArrayController 来显示对象的路线。在执行某些操作后,使用 controller.clear() 和 controller.addObjects() 方法再次填充数组。我需
我有一个在 Ember 中创建的自定义 View 。我真的很喜欢 {{yield}} helper 让我控制三明治的“面包”。但是,我现在想要做的是创建一个“双层”三明治,并有一个超过 1 个产量的
过去 6 个月我正在开发一个 Emberjs 组件。 当我尝试开发表格组件时,我开始遇到第一个性能问题。此表中的每个单元格都是 Ember.View,并且每个单元格都绑定(bind)到对象属性。当表格
我有一个名为 docTemplateID 的变量/操作。docTemplateID 的值可以是 1 或 2单击按钮 1 设置 docTemplateID = 1。单击“提交”按钮将使用新值创建 doc
我正在尝试编写一个小 Action 来搜索数据存储,顺便说一下,数据存储中已经加载了数据。我希望能够通过字符串(即名字)进行搜索。 这是我到目前为止的代码示例。 this.get() 正在从搜索表单中
我正在尝试在注册表单上创建提交操作。这是我的寄存器 handle : {{input class="form-control" value=username type="text" pl
我有一个我认为相当正常的 JSON 响应: "data": { ..... "user": { "name": "John", "surname": "Doe" } .
如何定义仅在按下特定修饰键时调用的操作(单击时)? allowedKeys当没有按下修饰键时也会执行该操作。 最佳答案 一种方法就是做 my item 在你的 Controller /父组件中
所以,这基本上就是我想要的。但我需要获取可以在 ember 检查器中看到的当前路径,但如何在组件中获取它?或者有更好的方法来做到这一点吗?也许是一项服务? import Ember from 'emb
我只是想循环遍历我生成的一些虚拟数据,这样我就可以设置网站的样式,我的路由器中有这个: import Ember from 'ember'; export default Ember.Route.ex
这就是我所拥有的。 2 种模型:“注释”和“用户”。注释有一个名为“用户”的字段,它使“1 个用户对应多个注释”进行复制。数据取自 Mirage。 备注型号: export default DS.Mo
我尝试复制搜索字段,就像它们在 emberjs.com 处显示的那样。但是由于某种原因,当输入查询并按 Enter 或单击提交按钮时,我的代码不断产生以下错误(在 google chrome 中):
我正在测试过滤器内容,仅显示 X 个结果,我必须使用计数器来执行此操作,因为适配器如何返回数据。 http://jsfiddle.net/eAvET/ 当您加载此修改后的示例时,显示 0 数据,但是当
我的应用程序有一个名为 Balance 的模型,我们可以在其中添加金额和说明。我创建了一个操作,当您单击按钮时添加一些余额记录,到目前为止效果很好。问题是我创建了一个名为“totalBalance”的
我正在使用 ember 的查询参数按布局类型过滤结果列表。我想检查指定的查询是否在 availableLayouts 中。我知道我可以检查该值是否在此数组中,但我不确定 ember 在什么时候设置“布
我有一段数据(对象),它从服务器端脚本打印为全局变量。 user = { id : 1, name: 'foo', avatar : 'http://foo.com/avatar.jpg'} 整个应用
我正在使用 Ember 构建一个单页音乐网络应用程序。每个轨道在页面上都表示为一个组件。给定页面上有许多轨道。当用户单击播放时,组件会更新其 UI 以反射(reflect)这一点,并且主路由会跟踪当前
我想将社交分享按钮(fb、twitter、vk)添加到我的 Ember 应用程序中。我找到了一些库并集成了它们,但它们有一个重要的限制。社交网络使用其机器人抓取共享页面,并从页面中检索特定的元属性。但
我试图用easyForm预选一个选择框。 https://github.com/dockyard/ember-easyForm 我做了一个JsBin:http://emberjs.jsbin.com/
我是一名优秀的程序员,十分优秀!