在Angular中,ngOnInit()方法只会在组件初始化时被调用一次,而不是在每次导航时被调用。如果您需要在每次导航时执行一些逻辑,您可以使用Angular的路由守卫来实现。下面是一种解决方法的代码示例:
AuthGuard
的路由守卫:import { Injectable } from '@angular/core';
import { CanActivate, ActivatedRouteSnapshot, RouterStateSnapshot, Router } from '@angular/router';
@Injectable({
providedIn: 'root'
})
export class AuthGuard implements CanActivate {
constructor(private router: Router) { }
canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): boolean {
// 在每次导航时执行逻辑
console.log('ngOnInit() called on navigation');
// 返回true以允许导航,返回false以阻止导航
return true;
}
}
AuthGuard
:import { NgModule } from '@angular/core';
import { Routes, RouterModule } from '@angular/router';
import { HomeComponent } from 'path-to-home-component';
import { AuthGuard } from 'path-to-auth-guard';
const routes: Routes = [
{
path: 'home',
component: HomeComponent,
canActivate: [AuthGuard] // 使用AuthGuard进行导航守卫
},
// 其他路由配置
];
@NgModule({
imports: [RouterModule.forRoot(routes)],
exports: [RouterModule]
})
export class AppRoutingModule { }
现在,每次导航到home
路由时,AuthGuard
的canActivate()
方法都会被调用,并执行您在其中定义的逻辑。