【发布时间】:2012-05-08 06:01:19
【问题描述】:
ExtJS 模型字段有映射选项。
fields: [
{name: 'brandId', mapping:'brand.id', type: 'int'},
{name: 'brandName', mapping:'brand.name', type: 'string'},
问题是:如果来自服务器的响应不包含某些字段(在我的示例中为品牌字段)并且定义了来自内部字段的映射,则 Ext Store 会静默加载任何记录。
有人对此有疑问吗?这是某种错误吗?
更新 说清楚:假设我的模型中有十个字段。来自服务器的响应有九个字段,缺少一个。如果该字段没有嵌套映射(映射:'x.y.z'),一切正常 - 存储加载记录,该字段为空。但是如果这个字段必须从某个嵌套字段中加载并且有映射选项 - store 无法加载任何内容。
更新 2 我找到了导致问题的代码。事实是:当 Ext 尝试从 Json 加载某些字段时,它会执行这样的检查
(source["id"] === undefined) ? __field0.defaultValue : source["id"]
但是当字段有映射选项(映射'brand.id')时,阅读器会这样做
(source.brand.id === undefined) ? __field20.defaultValue : source.brand.id
如果来源没有品牌字段,则会导致错误。
如果你遇到和我一样的问题:你可以通过重载Ext.data.reader.Json的方法createFieldAccessExpression
来修复它【问题讨论】:
-
如果商店未能在响应中找到它的记录,您会期待什么其他行为?我的意思是,你对这种行为有什么问题?
-
嗯,记录来自服务器,只是没有“品牌”字段。如果一条记录遗漏了某个字段并且没有映射,一切正常,商店加载记录,该字段为空
-
"(在我的示例中为品牌字段)" 您没有在此处显示品牌字段。你有一个brandId 和brandName。请澄清。
-
模型中没有品牌字段,但服务器响应中应该有品牌字段 "brand":{"id":"1","name":"Hyundai"} 我清楚了吗?
-
"The Store 静默加载任何记录失败"只是因为它无法确定服务器中
brand的实际数据是什么(响应中没有收到brand,所以怎么能商店获取brand.id 和brand.name)。如果brand未确定,商店如何知道该字段是否与服务器上的实际数据相比已更改以进行更新。所以这种情况下的事件处理是不可能的。
标签: extjs extjs4 store extjs4.1