作成したモデルに受信したJSONデータをマップしようとしています。問題は、JSONデータにネストされた配列があることです。だから私のやり方でデータをマッピングすることはできません。自分のやり方で間違いがあるのですか、それともJSONデータをマッピングする良い方法がありますか?ネストしたJSON配列をモデルに変換するAngular2
JSON-データ
{
"data": {
"apiName": "test-application",
"stages": [
{
"stage": "prod",
"id": "xxxxxxxx",
"methods": [
{
"id": "xxxxxx",
"path": "https://stackoverflow.com/users/create",
"httpMethods": [
"GET"
],
"methodName": "testMethod",
"url": "https://xxxx/xxxxx/xxxxxx"
}
]
},
{
"stage": "dev",
"id": "xxxxxxx",
"methods": [
{
"id": "xxxxxxx",
"path": "https://stackoverflow.com/users/create",
"httpMethods": [
"GET"
],
"methodName": "testMethod",
"url": "https://xxxxx/xxxxxx/xxxx"
}
]
}
]
}
}
モデル:サービスで
import {ApiStage} from "./ApiStage";
export class Api {
constructor(values: Object = {}){
Object.assign(this, values);
}
public apiName: string;
public stages: ApiStage[];
}
import {ApiMethod} from "./ApiMethod";
export class ApiStage {
constructor(values: Object = {}){
Object.assign(this, values);
}
public stage: string;
public id: string;
public methods: ApiMethod[];
}
export class ApiMethod {
constructor(values: Object = {}){
Object.assign(this, values);
}
public id: string;
public path: string;
public httpMethods: string[];
public methodName: string;
public url: string;
}
HTTP-方法:
getApi() {
return this.http.post(this.url, this.data, {headers: this.headers})
.map(this.extractData)
.map(api => new Api(api))
.catch((error: any) => Observable.of(error.json().error || 'Server error'));
}
private extractData(res: Response) {
let body = res.json();
return body.data || {};
}
どのようにC#モデルを生成しましたか?あなたのjsonをここに貼り付けてコピーしてください:http://json2csharp.com/ –
これはC#ではなく、タイプスクリプト – bobafett1
私の間違いですが、私には間違って見えます。http:// json2ts.com/どのようなエラーがありましたか? –