将嵌套的json映射到ember数据模型 [英] maping nested json to ember-data model
问题描述
我没有使用RESTAdapter,所以我创建了Ember对象,并为ajax requestig使用reopenClass方法和jquery ajax函数,代码是:
im not using RESTAdapter so i create Ember Object and using reopenClass method and jquery ajax function for ajax requestig and the code is :
OlapApp.Dimenssions = Ember.Object.extend({});
OlapApp.Dimenssions.reopenClass({
measure:Ember.A(),
find:function(cubeUniqueName){
var c = Ember.A();
var xhr = $.ajax({
type: 'POST',
dataType: 'json',
contentType: 'application/json',
url: 'http://localhost:9095/service.asmx/getDimension',
data: '{"cubeUniqueName":"'+cubeUniqueName+'"}',
success: function(response) {
var data = JSON.parse(response.d);
$.each(data.hierarchies,function(i,v) {
c.pushObject(OlapApp.Dimenssions.create(v));
});
console.log(c);
}
});
return c;
}
});
当 OlapApp.Dimenssions.find()
称为服务器响应一个这样的json:
when OlapApp.Dimenssions.find()
called the server response a json like this :
{
"uniqueName": "[Customers] = [Database].[Cube 2]",
"name": "Customers",
"caption": "Customers",
"dimensionUniqueName": null,
"description": "Description",
"levelUniqueName": null,
"hierarchyUniqueName": null,
"visible": true,
"hierarchies": [
{
"uniqueName": "[Customers]",
"name": "Customers",
"caption": "Customers",
"dimensionUniqueName": "[Customers]",
"levels": [
{
"uniqueName": "[Customers].[(All)]",
"name": "(All)",
"caption": "(All)",
"description": "Description",
"hierarchyUniqueName": "[Customers]",
"dimensionUniqueName": "[Customers]",
"visible": true
},
{
"uniqueName": "[Customers].[Country]",
"name": "Country",
"caption": "Country",
"description": "Description",
"hierarchyUniqueName": "[Customers]",
"dimensionUniqueName": "[Customers]",
"visible": true
}
]
}
]
}
第一个proplem在这里,我不能推送json corectly在 c arrary所以我尝试为此创建一个模型,模型代码是:
the first proplem is here that i cant push json corectly in c arrary so i try to create a model for this and the model code is :
OlapApp.RootMembers = DS.Model.extend({
id:DS.attr("number"),
uniqueName:DS.attr('string'),
name:DS.attr('string'),
caption:DS.attr('string'),
dimensionUniqueName:DS.attr('string'),
description:DS.attr('string'),
levelUniqueName:DS.attr('string'),
hierarchyUniqueName:DS.attr('string')
});
OlapApp.Levels = DS.Model.extend({
id:DS.attr("number"),
uniqueName:DS.attr('string'),
name:DS.attr('string'),
caption:DS.attr('string'),
hierarchyUniqueName:DS.attr('string'),
dimensionUniqueName:DS.attr('string'),
visible:DS.attr('boolean'),
description:DS.attr('string')
});
OlapApp.Hierarchies = DS.Model.extend({
id:DS.attr("number"),
uniqueName:DS.attr('string'),
name:DS.attr('string'),
caption:DS.attr('string'),
dimensionUniqueName:DS.attr('string'),
levels:DS.hasMany(OlapApp.Levels,{embedded:always}),
rootMembers:DS.hasMany(OlapApp.RootMembers,{embedded:always})
});
你可以看到真正的json返回的表单服务器这里
you can see real json that returned form server here
但是我如何将这个json映射到这些模型?如果我不能映射到模型,我可以将嵌套的json映射到Ember.Object。
but how can i map this json to these model ? if i cant map to model can i map nested json to Ember.Object.
推荐答案
我可以解决我的问题代码:
i can fix my problem with this line of code :
var data = JSON.parse(response.d);
c.pushObject(Ember.Object.create(data));
这篇关于将嵌套的json映射到ember数据模型的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!