在Angular 5中,您可以使用依赖注入来调用服务,并通过使用Observables来合并数据。
假设您有两个服务:DataService
和ApiService
。其中,DataService
负责从API获取数据,ApiService
负责实际的API调用。
首先,您需要在DataService
中注入ApiService
服务。在DataService
的构造函数中,您可以通过将ApiService
作为参数来实现注入。
import { Injectable } from '@angular/core';
import { ApiService } from './api.service';
@Injectable()
export class DataService {
constructor(private apiService: ApiService) { }
getData() {
return this.apiService.getData();
}
}
接下来,在ApiService
中,您可以使用http
模块来实际调用API并返回一个Observable。
import { Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http';
@Injectable()
export class ApiService {
constructor(private http: HttpClient) { }
getData() {
return this.http.get('your-api-url');
}
}
最后,在组件中,您可以使用DataService
来调用服务并合并数据。
import { Component, OnInit } from '@angular/core';
import { DataService } from './data.service';
import { Observable } from 'rxjs/Observable';
import 'rxjs/add/observable/forkJoin';
@Component({
selector: 'app-my-component',
template: `
{{ data }}
`,
})
export class MyComponent implements OnInit {
mergedData$: Observable;
constructor(private dataService: DataService) { }
ngOnInit() {
const data1$ = this.dataService.getData();
const data2$ = this.dataService.getData();
this.mergedData$ = Observable.forkJoin(data1$, data2$);
}
}
在上面的示例中,我们在组件的ngOnInit
方法中调用了getData
两次,并使用forkJoin
操作符将它们的结果合并为一个Observable。然后,我们通过在模板中使用async
管道来订阅这个Observable并显示合并后的数据。
请确保在AppModule
中正确地提供了DataService
和ApiService
服务。
这就是在Angular 5中使用Typescript调用服务并合并数据的解决方法。希望对您有所帮助!