我试图找到将json对象强制转换为Typescript对象的最佳方法。 我有一个http get服务,它返回一个用户列表。 我当前的版本工作,我已经从JSON函数添加到我的所有模型类,以使映射工作:
export class User {
constructor(
public pk: number,
public username: string,
public first_name: string,
public last_name: string,
public email: string,
public profile: UserProfile, ) {
}
static fromJSON(json: any): User {
let user = Object.create(User.prototype);
Object.assign(user, json);
user.profile = UserProfile.fromJSON(json.profile);
return user;
}
}
效果很好。但是有些东西我不会在角度2文档中得到。在英雄教程中,JSON以这种方式自动转换为对象:
getHeroes (): Observable<Hero[]> {
return this.http.get(this.heroesUrl)
.map(this.extractData)
.catch(this.handleError);
}
private extractData(res: Response) {
let body = res.json();
return body.data || { };
}
我无法使用此方法处理我的案例,我说body.data
未定义。
这种方法真的有效吗?
修改
我的http服务不会返回一组用户。它返回一个页面,其中包含一系列用户的结果&#39;属性。
{
"count": 2,
"next": null,
"previous": null,
"results": [
{
"pk": 48,
"first_name": "Jon",
"last_name": "Does",
"profile": {
"pk": 46,
"gender": "U"
}
},
{
"pk": 47,
"first_name": "Pablo",
"last_name": "Escobar",
"profile": {
"pk": 45,
"gender": "M"
}
}
]
}
我的服务代码:
private extractData(res: Response) {
let body = res.json().results;
return body || {}; //<--- not wrapped with data
}
search(authUser: AuthUser, terms: string): Observable<User[]> {
let headers = new Headers({
'Content-Type': 'application/json',
'X-CSRFToken': this.cookiesService.csrftoken,
'Authorization': `Token ${authUser.token}`
});
let options = new RequestOptions({ headers: headers });
return this.http.get(environment.server_url + 'user/?search=' + terms, options)
.map(this.extractData);
// .map((response: Response) => response.json());
}
我的搜索组件代码:
onSearch(terms: string) {
this.searchService.search(this.user, terms).subscribe(
response => {
console.log(response); // Return array of object instead of array of user
},
error => {
console.log(JSON.stringify(error));
},
() => { }
);
}
编辑2:
为了简化这个案例,我写了这个简单的代码:
test(){
let json_text=` [
{
"id": 1,
"text": "Jon Doe"
},
{
"id": 1,
"text": "Pablo Escobar"
}
]`;
console.log(<MyObject[]>JSON.parse(json_text)); // Array of objects
console.log(MyObject.fromJSON(JSON.parse(json_text))); // Array of 'MyObject'
}
export class MyObject{
id: number;
text: string;
static fromJSON(json: any): MyObject {
let object = Object.create(MyObject.prototype);
Object.assign(object, json);
return object;
}
}
console.log(<MyObject[]>JSON.parse(json_text))
返回对象列表console.log(MyObject.fromJSON(JSON.parse(json_text)))
返回一个
MyObject列表答案 0 :(得分:3)
这是因为在Angular教程中,json位于data属性中。
如教程中所述
不要假设服务器API。并非所有服务器都返回 具有数据属性的对象。
如果您没有用任何属性包装json,可以使用
private extractData(res: Response) {
let body = res.json();
return body || { }; //<--- not wrapped with data
}
更新
组件代码
onSearch(terms: string) {
this.searchService.search(this.user, terms).subscribe(
(response: SearchResponse) => { // <--- cast here
console.log(response);
},
error => {
console.log(JSON.stringify(error));
},
() => { }
);
}
答案 1 :(得分:0)
我对这个话题还很晚,但是发现自己陷入了同样的问题。我正在学习Angular,并希望将从HTTP服务器接收的JSON转换为我的模型对象。
服务等级
var ele:User;
let k=this.http.get<User>(url).subscribe(data => {
ele=data;
console.log(ele.count);
console.log(ele.results[0].first_name);
console.log(ele.results[0].profile.gender);
}
);
我的模型,用于保存JSON信息
export interface User{
count: string;
next: string;
previous: string;
results: Result[];
}
export interface Result{
pk: string;
first_name: string;
last_name: string;
profile:Profile;
}
export interface Profile{
pk: string;
gender:string;
}
就是这样。我正在使用Angular 6将JSON解析为对象