web-dev-qa-db-ja.com

キャッチされていない(約束)をデバッグする方法:EmptyError:router.navigateによって引き起こされるシーケンス内の要素はありませんか?

私は単純なangularルートを実装しようとしています

const appRoutes: Routes = [
   { path: ''        ,redirectTo: '/recipes', pathMatch: 'full'},
   { path: 'recipes'              , component: RecipesComponent},
   { path: 'recipes/:recipeName'  , component: RecipesComponent},
];

リストを生成する一部のコンポーネントでは、状態変数とルートの更新をクリックする機能がありますが、初期化時にサブスクライバーを取得するメカニズムもあります。

  ngOnInit() {
    this.route.params
      .subscribe(
        (params: {Params}) => {

          this.selectedRecipe = this.findRecipeByName(params['recipeName']);  
        });
  }


   navRecipe(recipeName: string): void {
      let path = '/recipes/' + recipeName;
      this.selectedRecipe = this.findRecipeByName(recipeName);
      this.router.navigate([path]);
   }

しかし、パラメーターを使用してコンポーネントにリダイレクトするリンクをクリックしようとすると、次のようになります:

core.js:1350 ERROR Error: Uncaught (in promise): EmptyError: no elements in sequence
EmptyError: no elements in sequence
    at new EmptyError (EmptyError.js:28)
    at FirstSubscriber._complete (first.js:154)
    at FirstSubscriber.Subscriber.complete (Subscriber.js:122)
    at MergeMapSubscriber._complete (mergeMap.js:150)
    at MergeMapSubscriber.Subscriber.complete (Subscriber.js:122)
    at MapSubscriber.Subscriber._complete (Subscriber.js:140)
    at MapSubscriber.Subscriber.complete (Subscriber.js:122)
    at EmptyObservable._subscribe (EmptyObservable.js:83)
    at EmptyObservable.Observable._trySubscribe (Observable.js:172)
    at EmptyObservable.Observable.subscribe (Observable.js:160)
    at new EmptyError (EmptyError.js:28)
    at FirstSubscriber._complete (first.js:154)
    at FirstSubscriber.Subscriber.complete (Subscriber.js:122)
    at MergeMapSubscriber._complete (mergeMap.js:150)
    at MergeMapSubscriber.Subscriber.complete (Subscriber.js:122)
    at MapSubscriber.Subscriber._complete (Subscriber.js:140)
    at MapSubscriber.Subscriber.complete (Subscriber.js:122)
    at EmptyObservable._subscribe (EmptyObservable.js:83)
    at EmptyObservable.Observable._trySubscribe (Observable.js:172)
    at EmptyObservable.Observable.subscribe (Observable.js:160)
    at resolvePromise (zone.js:824)
    at resolvePromise (zone.js:795)
    at eval (zone.js:873)
    at ZoneDelegate.invokeTask (zone.js:425)
    at Object.onInvokeTask (core.js:4621)
    at ZoneDelegate.invokeTask (zone.js:424)
    at Zone.runTask (zone.js:192)
    at drainMicroTaskQueue (zone.js:602)
    at ZoneTask.invokeTask [as invoke] (zone.js:503)
    at invokeTask (zone.js:1540)
17
Iancovici

Angular v 4.4.6。で同じエラーが発生しました。エラーを解決するために見つけた2つの代替ソリューションがありました。1つはpathMatch: 'full'すべてのルート定義に。もう1つは、rxjsをv5.5.3以下にダウングレードすることでした。一方が機能しない場合は、おそらくもう一方が機能します。

更新:この問題はrxjs v5.5.5で修正されたようです。 Angular 5.0.5を使用するプロジェクトで、rxjsをv5.5.5にアップグレードした後、エラーが発生しなくなりました。

24
EvanMorrison

角度の最新バージョンのバグ。追加 pathMatch: 'full'すべてのルートへ。

 {
    path: '',
    component: HomeComponent,
    pathMatch: 'full'
  },
  {
   path: 'about',
   component: AboutComponent,
   pathMatch: 'full'
  },
15
Ericky

Angular 5.0.1およびrxjs 5.5.3で同じエラーが発生しました。routes配列の順序を変更したときに例外は発生しませんでした。

const appRoutes: Routes = [
    { path: '',                    redirectTo: '/recipes', pathMatch: 'full'},
    { path: 'recipes/:recipeName', component: RecipesComponent},
    { path: 'recipes',             component: RecipesComponent},
];

より詳細なパス(recipes/:recipeName)一般パス(recipes)の前。

1
Daxez