0

我正在尝试使用 Sproutcore 呈现 UI,其中我有一个列表列表。有一个垂直的数据列表,其中每个关联的项目都有自己的项目列表。我已经根据我对 Sproutcore 的了解设置了我认为合适的模型。

模型:

App.VerticalData = SC.Record.extend({
  someField: SC.Record.attr(Boolean),
  associatedListOfData: SC.Record.toMany("App.HorizontalData", {
    inverse: "vertical",
    isMaster: YES
  })
});

App.HorizontalData = SC.Record.extend({
  someForeignKeyField: SC.Record.attr(Number),
  vertical: SC.Record.toOne("App.VerticalData", {
    inverse: "associatedListOfData",
    isMaster: NO
  }),
});

我在垂直列表的 ListItemView 中添加了一个子视图,并修改了子类,以便它将水平列表中的项目布局......嗯......水平。我遇到的问题是,我似乎能够从 toMany() 关系中获取数据以绑定到此水平列表的唯一方法是对垂直列表中的每个项目执行以下操作。

horizontalListView.set('content', App.store.find(SC.Query.local(App.HorizontalData, {
  conditions: 'someForeignKeyField = ' + keyValueOfVerticalItem)
})));

这是痛苦的,可悲的缓慢。我不明白为什么我似乎不能只将计算属性的结果用于当前垂直列表项的 toMany() 字段。有人可以在这里提供一些指导吗?也许我错过了一些愚蠢的东西。

如果我尝试直接访问该属性,这是我得到的结果:

Object
SproutCore18001994610927067697: "sc1271"
__sc_super__: Object
_bindings: Array[0]
_kvo_cacheable: true
_kvo_changeLevel: 0
_kvo_changes: null
_kvo_cloned: Object
_kvo_content_observed_keys: Object
_kvo_dependents: Object
_kvo_revision: 2
_object_toString: "SC.ManyArray:sc1271"
_observableInited: true
_observers: Array[0]
_prevStoreIds: Array[167]
_properties: Array[15]
_records: null
bindings: Array[0]
manyAttribute: Object
outlets: Array[0]
propertyName: "associatedListOfData"
propertyRevision: 2
record: Object
recordType: App.HorizontalData
__proto__: Object

我不知道这看起来是否正确。所以我有可能在我用于测试数据的 FIXTURES 中仍然没有正确定义一些东西。我在 associatedListOfData 字段中输入的信息是与 Horizo​​ntalData 表中元素的 GUID 对齐的数字数组。

4

2 回答 2

0

经过更多测试和实验后,我认为问题可能与 App.store.dataHashes 不包含相关记录的值有关。这显然必须手动填充关联以协调记录,并且不会在关联中构造 SC.ManyArray 时自动填充存储。我不知道这是否是 Sproutcore 中的一个错误,或者它是否是预期的行为。

我能够通过使用 App.Horizo​​ntalData 表上的查询填充此属性来解决此问题,该表返回了我为我的 FIXTURE 生成的所有记录。如果商店有可用的散列数据,则使用作为 ListView 内容返回的 SC.ManyArray 可以按预期工作。

于 2012-08-23T19:29:03.480 回答
0

我认为您的记录定义可能有问题。如果您暂时忘记了列表视图,然后打开控制台,您可以抓取一条App.VerticalData记录并询问它是什么associatedListOfData吗?

例子:

var vertical_id = 1;
var vertical = App.store.find('App.VerticalData', vertical_id);

console.log(vertical.get('associatedListOfData'));

如果打印不正确,那么您就知道记录本身有问题,而不是视图有问题。

我将不得不在这里猜测一下,但是由于您在创建记录时没有指定密钥,我敢打赌 SC 根本无法将两者联系在一起。除非您的数据库键是associatedListOfDataand vertical,否则它可能不起作用。

如果这不能解决问题,您能否更新您的代码以显示它的实际编写方式,并可能向我们展示您的服务器发送的 JSON?

于 2012-08-22T21:56:03.743 回答