使用Typescript从Angular 2中的Observable获取项目

时间:2016-04-25 17:10:25

标签: javascript typescript angular typescript1.8

我正在尝试从Angular 2中的一个observable获取一个由服务提供的项目。到目前为止,我可以订阅observable并查看控制台中的内容,但不能通过它的ID过滤掉项目。我在下面尝试了以下内容,但得到一个空白屏幕。任何提示赞赏。

service.ts:

getJobs() {
  this.observableData = this._http.get('json_path/')
      .map(res => res.json())
      .do(val => {
        this.result = val;
        this.observableData = null;
      })
      .share();
  return this.observableData;
}

component.ts:

let id = this._routeParams.get('id');
this._jobService.getJobs().map(jobs => jobs.filter(item => item.id === id).subscribe(job => this.job = job)[0]);

1 个答案:

答案 0 :(得分:5)

我想你想要这样的东西:

let id = this._routeParams.get('id');
this._jobService.getJobs().map(jobs => {
  return jobs.filter(item => item.id === id)[0];
}).subscribe(job => this.job = job));

您无法订阅jobs.filter()

的结果