angular快捷键小记以及路由策略

it2022-05-05  181

建立路由(module):

ng g m xxx --routing

建立页面(component):

ng g c xxx;

配置路由守卫(guard):

ng g g  auth/auth

配置服务(server):

ng g s auth/auth

懒加载路由;

RouterModule.forRoot() 和 RouterModule.forChild()

RouterModule对象为提供了两个静态的方法:forRoot()和forChild()来配置路由信息。

RouterModule.forRoot()方法用于在主模块中定义主要的路由信息,RouterModule.forChild()与 Router.forRoot()方法类似,但它只能应用在特性模块中。

即根模块中使用forRoot(),子模块中使用forChild()。

应用:

只在根模块 AppRoutingModule 中调用 RouterModule.forRoot(如果在 AppModule 中注册应用的顶级路由,那就在 AppModule 中调用)。 在其它模块中,你就必须调用RouterModule.forChild方法来注册附属路由。

注意:路由配置的顺序很重要。 路由器会接受第一个匹配上导航所要求的路径的那个路由。

路由守卫

Angular路由守卫: 在进入或离开某路由时,用于判断是否可以离开、进入某路由;;; return true 代表可以进入当前路由;return false 代表不可以进入当前路由,但可以进入自定义的路由;

路由守卫与路由的关系

路由守卫只只能应用于路由项上;路由守卫可以应用于多个路由项;每个路由项也可以有多个路由守卫;

路由守卫通过实现如下接口来操作:

canActivate: 控制是否允许进入路由。(通过return true/false决定)

canActivateChild: 等同 canActivate,只不过针对是所有子路由。

canDeactivate: 控制是否允许离开路由。

canLoad: 控制是否允许延迟加载整个模块。

作用

验证身份

RouteReuseStrategy

// Angular路由复用策略RouteReuseStrategy(常用于实现Tab页签切换页面)

参考上一篇文章


最新回复(0)