当您对单个记录进行请求时,它使用不同的序列化程序端点并期望数据采用不同的格式。它期望的格式是:
{
customer: {
id: 1,
currency:1
},
currencies: [
{
id:1,
prop: 'foo'
}
]
}
序列化器中的端点是extractSingle。随意提取extractArray 中相似的部分并分享。
假装你的有效载荷是:
{
customer:{
id:3,
name:"Joue",
currency:{
id:5,
iso_code:"BDT"
}
}
}
您的extractSingle 将是
extractSingle: function(store, type, payload, id) {
var customer = payload.customer,
currencies = [];
var currency = customer.currency;
delete customer.currency;
if(currency){
currencies.push(currency);
customer.currency = currency.id;
}
payload = { customer:customer, currencies: currencies };
return this._super(store, type, payload, id);
}
这是示例,其中包含客户 3 的响应
http://jsbin.com/OxIDiVU/545#/customers/3/contact
您的属性名称应与模型内部匹配,并且根名称(此处为货币)应为记录类型的复数形式。
{
customer: {
id: 1,
default_currency:1
},
currencies: [
{
id:1,
prop: 'foo'
}
]
}