我挣扎了几个小时,试图使用Ember-Data来实现这一点,但没有结果,所以我想我试了一试Ember-Model;仍然没有joy。
我有以下几点:
App.Item = Ember.Model.extend({
itemName: Ember.attr(),
});
App.Strat = Ember.Model.extend({
stratName: Ember.attr(),
items: Ember.hasMany('App.Item',{key: 'items', embedded: true});
App.Strat.adapter = Ember.FixtureAdapter.create();
App.Strat.FIXTURES =
[
{id: 1, stratName: 's1', items:
[{id: 1, itemName: 'I1'}]},
{id: 2, stratName: 's2', items:
[{id: 2, itemName: 'I2'},
{id: 3, itemName: 'l3'}]}
];到目前为止,一切似乎都运行得很好。我可以通过模板显示夹具数据。我想要做的是允许用户添加额外的strat记录,通过在屏幕上显示预先填充的strat记录,允许用户进行修改,然后将其与从夹具数据加载的两个strat记录一起保存。我尝试了以下几种方法:
var dummyStrat =
{id: 100, stratName: "s5", items:
[{id: 101, itemName: "I5", strategy: 100}]};
var newStrat = App.Strat.create (dummyStrat);
newStrat.save();这产生了以下错误:
TypeError: this.get(key).toJSON不是函数。
但如果我这样做了,没有错误:
var dummyStrat =
{id: 100, stratName: "s5"};
var newStrat = App.Strat.create (dummyStrat);
newStrat.save();我做错了什么?
发布于 2013-11-01 00:58:29
如果从create调用中删除strategy: 100会发生什么?我在我的应用程序中有几乎相同的代码,除了我没有设置任何不是我的模型中的属性的变量。
我的另一个建议是尝试将项键重命名为stratItems,这样键就不会与计算出的hasMany属性同名。
https://stackoverflow.com/questions/19626494
复制相似问题