Angular 2 aktuelle Route in Wache erhalten

Ich habe eine AccessGuard-Klasse in meinem Projekt, deren Aufgabe es ist, zu bestimmen, ob Benutzer auf die Route zugreifen können oder nicht. Ich habe das @ benutrouter.url, um die aktuelle Route abzurufen, aber die URL gibt die Route zurück, bevor zur neuen Route navigiert wird, als würde ich mich auf der Route des Benutzers befinden, und ich klicke auf die Route des Kandidaten, damit die URL Benutzer anstelle von Kandidaten zurückgibt, die den Zugriff auf das bestätigen sollen Route Dies ist meine Routendatei:

const routes:Routes = [
{
    path:'',
    component:PanelComponent,
    canActivate:[AuthGuard,AccessGuard],
    canActivateChild:[AuthGuard,AccessGuard],
    children:[
        {
            path:'dashboard',
            component:DashboardComponent
        },
        {
            path:'users',
            component:UsersComponent
        },
        {
            path:'users/:id',
            component:ShowUserComponent
        },
        {
            path:'candidates',
            component:CandidatesComponent
        },
        {
            path:'permissions',
            component:PermissionsComponent
        },
        {
            path:'holidays',
            component:HolidaysComponent
        },
        {
            path:'candidate/:id',
            component:CandidateComponent
        },
        {
            path:'salary/create',
            component:InsertSalaryComponent
        },
        {
            path:'document/create',
            component:InsertDocumentComponent
        },
        {
            path:'leave/create',
            component:InsertLeaveComponent
        }
    ]
}

];

und das ist mein Zugangswächter:

permissions;
currentRoute;
constructor(private authService:AuthService,private router:Router){
    this.permissions = this.authService.getPermissions();
}

canActivate(){
    return this.checkHavePermission();
}

canActivateChild(){
    console.log(this.router.url);
    return this.checkHavePermission();
}

private checkHavePermission(){
    switch (this.router.url) {
        case "/panel/users":
            return this.getPermission('user.view');
        case '/panel/dashboard':
            return true;
        case '/panel/candidates':
            return this.getPermission('candidate.view');
        default:
            return true;
    }
}


getPermission(perm){
    for(var i=0;i<this.permissions.length;i++){
        if(this.permissions[i].name == perm ){
            return true;
        }
    }
    return false;
}

Antworten auf die Frage(6)

Ihre Antwort auf die Frage