使用 Observable 解决 Angular 2 路由器

标签 angular angular2-routing rxjs5

在 Angular 2 RC.5 发布后,引入了路由器解析。 Here使用 Promise 演示示例,如果我使用 Observable 向服务器发出请求,如何做同样的事情?

搜索服务.ts

searchFields(id: number) {
  return this.http.get(`http://url.to.api/${id}`).map(res => res.json());
}

搜索解析.service.ts

import { Injectable } from '@angular/core';
import { Router, Resolve, ActivatedRouteSnapshot } from '@angular/router';
import { Observable } from 'rxjs/Observable';

import { SearchService } from '../shared';

@Injectable()
export class SearchResolveService implements Resolve<any> {

  constructor(
    private searchService: SearchService ,
    private router: Router
  ) {}

  resolve(route: ActivatedRouteSnapshot): Observable<any> | Promise<any> | any {
    let id = +route.params['id'];
    return this.searchService.searchFields(id).subscribe(fields => {
      console.log('fields', fields);
      if (fields) {
        return fields;
      } else { // id not found
        this.router.navigate(['/']);
        return false;
      }
    });
  }
}

搜索.component.ts

ngOnInit() {
  this.route.data.forEach((data) => {
    console.log('data', data);
  });
}

获取 Object {fields: Subscriber} 而不是真实数据。

最佳答案

不要在您的服务中调用 subscribe() 而是让路由订阅。

改变

return this.searchService.searchFields().subscribe(fields => {

import 'rxjs/add/operator/first' // in imports

return this.searchService.searchFields().map(fields => {
  ...
}).first();

这样返回一个Observable而不是一个Subscription(由subscribe()返回)。

当前路由器等待可观察对象关闭。您可以使用 first() 运算符确保它在发出第一个值后关闭。

关于使用 Observable 解决 Angular 2 路由器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39066604/

相关文章:

javascript - 使用 redux-thunk 和 redux-observable

java - 如果用户已经在 J​​ava 中进行了身份验证,请在 Angular 屏幕上保持用户登录状态?

javascript - Angular2如何删除ngFor中的元素

javascript - 如何将服务中的数据分配给 JSON?

angular - 如何从父路由的组件访问已激活的子路由的数据?

angular - 带参数的 RouterLink 的 RouterLinkActive (/dynamic)

angular - 从 child 那里访问 Angular 父路由数据

rxjs - 使用 rxjs 5 运行平均值

javascript - Angular 5,如果第一个函数有效则执行新函数

javascript - 等待用 RxJs 解决的 promise