我想创建一个停用守卫,只有在子路线之外导航时才会触发。
在rc4 ("@angular/router":"3.0.0-beta.1")中,此代码的工作方式如下所述:
path: '',
component: RootComponent,
canDeactivate: [CanDeactivateGuard],
children: [
{
path: '',
component: XComponent,
},
{
path: 'somepath',
component: YComponent
}
]
}
在本例中,从XComponent导航到YComponent不会触发去激活防护,但例如导航到"someNotChildComponent“会触发去激活防护。
在更新到@angular/route 3.0.0-rc.1之后,每次路径更改都会触发防护。什么是正确的行为?有没有更好的方法来处理这种情况?
发布于 2016-08-29 00:32:30
我相信你可以添加
canDeactivate: [CanDeactivateGuard]
在子路由定义中,而不是在父路由中。
发布于 2017-01-17 06:14:51
这是一个bug,现在它可以正常工作了。
https://stackoverflow.com/questions/39192912
复制相似问题