如何使用Angular5从服务器端获取数据。我想在Angular5中获得呼叫
我试过这个:
getField (): Observable<b_fld[]> {
return this.http.get<fld[]>(this.fieldUrl)
.pipe(
tap(fields => console.log(`fetched fields`))
);
}发布于 2018-07-02 18:29:35
我这样做的方式是。这是我的service.ts设置。
import { HttpClient, HttpHeaders } from '@angular/common/http';
import { Observable } from 'rxjs';导入HttpClient和HttpHeaders,然后按如下所示进行设置
accessToken;
apiUrl = environment.apiUrl; // Url Reads http://my-api.com
// Only Needed if you have headers
headers = new HttpHeaders()
.set('Authorization', this.accessToken);
constructor(
private http: HttpClient
) { }
getMyData(): Observable<any> {
return this.http.get(
this.apiUrl + '/my-data', // Url Reads http://my-api.com/my-data
{headers: this.headers} // Include Headers If needed
);
}然后,在我的compoinent.ts文件中,如下所示。
import { MyService } from '../../services/my.service';
...
data;
...
constructor(
...
private myService: MyService
...
) { }
async ngOnInit() {
try {
await this.getData();
} catch (error) {
console.log(error);
}
this.loaded = true;
}
async getData() {
this.data = await this.getMyData();
}
// Get the Data
getMyData() {
return new Promise((resolve, reject) => {
this.myService.getMyData()
.subscribe(
data => {
resolve(data);
}, err => {
reject(err);
}
);
});
}https://stackoverflow.com/questions/51133591
复制相似问题