在Angular中,我们可以使用Typescript来定义返回模型。在HTTP请求后,我们需要将服务器返回的JSON数据转化为前端能够理解的对象。但是,有些时候我们会遇到一些类型错误,导致数据无法正确地转化。下面是一个解决方法。
首先,我们创建一个接口,用于定义返回数据模型:
interface Person {
id: number;
name: string;
age: number;
}
然后,在service中定义一个新的函数,用于获取数据:
import { Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http';
import { Observable } from 'rxjs';
import { Person } from './person.model';
@Injectable({
providedIn: 'root'
})
export class PersonService {
constructor(private http: HttpClient) { }
getPerson(id: number): Observable {
return this.http.get('https://myapi.com/person/' + id);
}
}
这里我们使用了一个泛型,指定了get请求的返回类型。同时,我们也指定了要返回的接口类型。
在组件里,我们可以这样使用:
import { Component, OnInit } from '@angular/core';
import { PersonService } from './person.service';
import { Person } from './person.model';
interface Error {
status: number;
message: string;
}
@Component({
selector: 'app-person',
template: `
Error: {{ error.status }} {{ error.message }}
Name: {{ person.name }}
Age: {{ person.age }}
`,
styleUrls: ['./person.component.css']
})
export class PersonComponent implements OnInit {
person: Person;
error: Error;
constructor(private personService: PersonService) { }
ngOnInit(): void {
this.personService.getPerson(1).subscribe(
(data: Person) => {
this.person = data;
},
(error: Error) => {
this.error = error;
}
);