- 检查数据请求是否成功。在服务中使用 console.log() 打印数据,确认数据请求是否返回。如果没有返回,检查请求 URL 和参数是否正确。
import { Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http';
@Injectable({
providedIn: 'root'
})
export class DataService {
constructor(private http: HttpClient) { }
getData() {
return this.http.get('https://api.example.com/data');
}
}
- 确认数据是否正确传递到组件。在组件中调用服务的 getData() 方法,并使用异步管道(async pipe)在模板中订阅数据流。如果数据流正常订阅,数据应该在模板中渲染出来。
import { Component, OnInit } from '@angular/core';
import { DataService } from '../data.service';
@Component({
selector: 'app-data-component',
template: `
`,
styleUrls: ['./data.component.css']
})
export class DataComponent implements OnInit {
data$;
constructor(private dataService: DataService) { }
ngOnInit() {
this.data$ = this.dataService.getData();
}
}
- 确认数据类型是否正确。在服务中声明返回类型,并为返回的数据提供正确的接口(interface)定义。如果数据类型不正确,可能会导致数据无法正确渲染。
import { Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http';
import { Observable } from 'rxjs';
import { IData } from './data.interface';
@Injectable({
providedIn: 'root'
})
export class DataService {
constructor(private http: HttpClient) { }
getData(): Observable {
return this.http.get('https://api.example.com/data');
}
}
export interface IData {
id: number;
name: string;
description: string;
}