1

//看守服务

import { Injectable } from '@angular/core';
import { CanActivate, ActivatedRouteSnapshot, RouterStateSnapshot, CanActivateChild } from '@angular/router';
import { Observable } from 'rxjs/Observable';

@Injectable()
export class AuthGuardService implements CanActivate {

  constructor() {
  }
    canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): boolean | Observable<boolean> | Promise<boolean> {
    console.log("can activate called");
    return true;
  }


}


//route
const APP_ROUTES = [{
    path: 'login',
    CanActivate: [AuthGuardService],
    component: login
}

因此,当登录页面加载时,它不会调用可以激活方法和打印控制台。我创建了一个警卫服务并在路由中添加了 CanActivate 属性。

4

1 回答 1

1

这是因为您canActivate的应用程序路由中有一个大写 C 字母。确保您已AuthGuardService在 app.module.ts 提供程序数组中注册。

于 2018-02-22T07:42:17.730 回答