2016-07-26 12 views
1

のためのプロバイダだから私のコードは次のようになりません:Angular2ルータcanActivateは偽

export const routes: RouterConfig = [ 
    { 'path': '', redirectTo: '/jobs', terminal: true, canActivate: [tokenNotExpired()] }, 
    { path: 'account', component: AccountComponent, canActivate: [!tokenNotExpired()] }, 
    { path: 'login', component: LoginComponent }, 
    ...WihRoutes 
]; 

私は、「アカウント」にナビゲートしてみてくださいたびに、ルーティングはそれが必要として失敗しますが、何らかの理由で、それはまた次のコンソールを提供しますエラー:

browser_adapter.ts:82 EXCEPTION: Error: Uncaught (in promise): No provider for false!BrowserDomAdapter.logError @ browser_adapter.ts:82BrowserDomAdapter.logGroup @ browser_adapter.ts:93ExceptionHandler.call @ exception_handler.ts:58(anonymous function) @ application_ref.ts:374schedulerFn @ async.ts:148SafeSubscriber.__tryOrUnsub @ Subscriber.ts:240SafeSubscriber.next @ Subscriber.ts:192Subscriber._next @ Subscriber.ts:133Subscriber.next @ Subscriber.ts:93Subject._finalNext @ Subject.ts:154Subject._next @ Subject.ts:144Subject.next @ Subject.ts:90EventEmitter.emit @ async.ts:133onError @ ng_zone.ts:142onHandleError @ ng_zone_impl.ts:95ZoneDelegate.handleError @ zone.js:327Zone.runGuarded @ zone.js:233_loop_1 @ zone.js:487drainMicroTaskQueue @ zone.js:494ZoneTask.invoke @ zone.js:426 browser_adapter.ts:82 STACKTRACE:BrowserDomAdapter.logError @ browser_adapter.ts:82ExceptionHandler.call @ exception_handler.ts:61(anonymous function) @ application_ref.ts:374schedulerFn @ async.ts:148SafeSubscriber.__tryOrUnsub @ Subscriber.ts:240SafeSubscriber.next @ Subscriber.ts:192Subscriber._next @ Subscriber.ts:133Subscriber.next @ Subscriber.ts:93Subject._finalNext @ Subject.ts:154Subject._next @ Subject.ts:144Subject.next @ Subject.ts:90EventEmitter.emit @ async.ts:133onError @ ng_zone.ts:142onHandleError @ ng_zone_impl.ts:95ZoneDelegate.handleError @ zone.js:327Zone.runGuarded @ zone.js:233_loop_1 @ zone.js:487drainMicroTaskQueue @ zone.js:494ZoneTask.invoke @ zone.js:426 browser_adapter.ts:82 Error: Uncaught (in promise): No provider for false! at resolvePromise (zone.js:538) at zone.js:515 at ZoneDelegate.invoke (zone.js:323) at Object.onInvoke (ng_zone_impl.ts:72) at ZoneDelegate.invoke (zone.js:322) at Zone.run (zone.js:216) at zone.js:571 at ZoneDelegate.invokeTask (zone.js:356) at Object.onInvokeTask (ng_zone_impl.ts:61) at ZoneDelegate.invokeTask (zone.js:355)

フォーマットがひどいため、エラーの画像も表示されます。 Stacktrace

私はこれがなぜ起こるのかについての手掛かりはありません - 誰か他の人ですか?

+0

どう 'tokenNotExpired()'のように見えるんで提供? –

+0

true/falseを返します。 canActivateを書くと同じことが起こります:false – yusijs

答えて

0

canActivate: [!tokenNotExpired()]に渡される値はプロバイダーである必要があります。 !tokenNotExpired()は有効なプロバイダーではありません。

canActivate: ['tokenExpired'] 
canActivate: ['!tokenExpired'] 

とブートストラップやAPP_ROUTER_PROVIDERS

bootstrap(AppComponent, [ 
    {provide: 'tokenExpired', useValue: (a: any, b: any) => tokenExpired()} 
    {provide: '!tokenExpired', useValue: (a: any, b: any) => !tokenExpired()} 
]); 
+0

私が知る限り、canActivateにプレーンなfalseを渡すにはプロバイダは必要ありませんか?それがそうであれば、私はそれのような何かを述べるいくつかのドキュメントを愛するだろう。 – yusijs

+0

https://angular.io/docs/ts/latest/guide/router.html#!#can-activate-guardにガードを提供する方法を示します。 https://github.com/angular/angular/blob/b42411ba1f6d0f989e5fa846524d3d9e2425e834/modules/%40angular/router/test/router.spec.ts#L849には、常にfalseを指定する方法が示されています。私はむしろあなたがあなたの質問に示したことが働くはずであることを説明する文書を見たいと思います。 –

+0

ガードの戻り値がルータの動作を制御します。 trueを返した場合、ナビゲーションプロセスは続行します falseを返した場合、ナビゲーションプロセスは停止し、ユーザーはそのままになります。 – yusijs

関連する問題