Angular 2路由器解析为Observable

拉哈特

在发布Angular 2 RC.5之后,引入了路由器解析。这里演示了Promise的示例,如果我使用Observable向服务器发出请求,该怎么做?

search.service.ts

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

search-resolve.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;
      }
    });
  }
}

search.component.ts

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

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

贡特·佐赫鲍尔(GünterZöchbauer)

不要呼叫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()运算符确保在发出第一个值后将其关闭

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章

来自分类Dev

使用HTML5路由时,Angular 2的路由器是否损坏?

来自分类Dev

Angular 2路由器导航,参数值为1

来自分类Dev

路由时Angular 2路由器刷新页面

来自分类Dev

带有子路由器的Angular2路由器不起作用

来自分类Dev

Angular 2路由器事件监听器

来自分类Dev

获取对Angular 2路由器中当前路由的组件的引用?

来自分类Dev

新的Angular2路由器配置

来自分类Dev

Angular 2路由器-CanActivate Guard

来自分类Dev

Angular 2路由器

来自分类Dev

angular2 rc3路由器alpha 3.0.0.7默认路由

来自分类Dev

与Angular 2路由器截取路由请求

来自分类Dev

Angular 2路由器+ angular-cli

来自分类Dev

Angular2路由器VS ui-router-ng2 VS ngrx路由器

来自分类Dev

Angular2路由器,从url获取路由数据,以显示面包屑

来自分类Dev

Angular 2路由器错误:路由“ undefined”的无效配置

来自分类Dev

.otherwise或新Angular2路由器中的/ **以通过通配符路由非路由

来自分类Dev

Angular 6路由器过渡

来自分类Dev

带有子路由器的Angular2路由器不起作用

来自分类Dev

Angular2路由器,内容更改,如何避免路由和重建页面

来自分类Dev

Angular 2路由器+ angular-cli

来自分类Dev

Angular2路由器和导航

来自分类Dev

Angular 2 RC4路由器在激活之前已获得预期的路由

来自分类Dev

.otherwise或新Angular2路由器中的/ **以通过通配符路由非路由

来自分类Dev

Angular 2 RC5路由器-嵌套路由

来自分类Dev

Angular 2应用程序和Angular 2路由器的异步性问题

来自分类Dev

Angular 2路由器-根URL上的辅助路由

来自分类Dev

Angular 2路由器无法正常工作

来自分类Dev

Angular 2路由器与路径不匹配

来自分类Dev

Angular 2路由器:未显示儿童

Related 相关文章

热门标签

归档