单击链接时,我想导航到不同页面/组件的片段。即使尝试了多种方法,我也无法实现这一目标:
关联:
<a routerLink="/main/dash" fragment="dir">View</a>
目标 html/模板:
<!-- Other elements -->
<app-dir id="dir"></app-dir>
路由器配置:
{
path: 'main',
component: LayoutComponent,
children: [{
path: 'dash',
loadChildren: () => import('src/app/features/dash/dash.module').then(m => m.DashModule),
canActivate: [AuthGuard]
}]
// Other code
}
// Other code
imports: [RouterModule.forRoot(appRoutes, { useHash: true, anchorScrolling: 'enabled', onSameUrlNavigation: 'reload' })],
单击“查看”链接时,系统导航到/main/dash
路径/页面/组件,但它不会在第一次滚动到片段。一旦我在主页上,当我点击相同的导航链接(视图 - 位于标题中)时,它会滚动到片段。
即当我已经在同一个页面/组件上时,AnchorScrolling 起作用,但如果源是不同的页面/组件,则不起作用。
我也尝试使用(click)
&this.router.navigate()
而不是使用 routerLink - 但结果是一样的。
我确实使用HashLocationStrategy
.
任何帮助,将不胜感激。
谢谢!
更新:
在深入挖掘之后,页面加载 Angular 之后的片段路由是我面临的确切问题。似乎还没有可用的解决方案?:https ://github.com/angular/angular/issues/30139