Angular对某些路由移除了base-href。
创始人
2024-10-24 15:31:41
0

在使用 Angular 路由时需要注意,如果在根模块中设置了 base-href,在使用 loadChildren 懒加载模块时会移除这个 base-href,导致路由无法正确匹配。因此需要在懒加载模块中重新设置 base-href。

示例代码:

// app.module.ts @NgModule({ imports: [ CommonModule, RouterModule.forRoot(routes, { initialNavigation: 'enabled', relativeLinkResolution: 'legacy', }), ], }) export class AppModule {}

// lazy.module.ts @NgModule({ imports: [ CommonModule, RouterModule.forChild([ { path: '', component: LazyComponent, children: [ { path: 'child', component: LazyChildComponent, data: { baseHref: '/lazy', }, }, ], }, ]), ], }) export class LazyModule { constructor( private router: Router, private activatedRoute: ActivatedRoute ) { this.router.events .pipe(filter((e) => e instanceof NavigationEnd)) .subscribe(() => { const { root } = this.activatedRoute; const { baseHref } = root.firstChild.snapshot.data; if (baseHref) { const base = document.createElement('base'); base.href = baseHref; const head = document.getElementsByTagName('head')[0]; head.insertBefore(base, head.firstChild); } }); } }

上述代码中,我们在路由配置中加入了一个 data 属性,用来存储每个子路由需要设置的 base-href。在 LazyModule 的 constructor 中通过订阅路由事件,在路由变化时手动插入新增的 base 标签来设置 base-href。这个方法可以避免 Angular 移除 base-href 导致的路由匹配问题。

相关内容

热门资讯

详细透视!wepoker透视底... 详细透视!wepoker透视底牌,微信小程序微乐辅助器免费下载,方案教程(有挂技术)-哔哩哔哩1、点...
开挂透视!hhpoker哪个俱... 开挂透视!hhpoker哪个俱乐部靠谱,微信小程序微乐跑得快技巧,步骤教程(有挂教程)-哔哩哔哩开挂...
分享透视!云扑克有透视吗,微乐... 分享透视!云扑克有透视吗,微乐小程序黑科技下载,步骤教程(有挂秘笈)-哔哩哔哩1、金币登录送、破产送...
总结透视!哈糖大菠萝免费辅助器... 总结透视!哈糖大菠萝免费辅助器,微信小程序多乐辅助器,练习教程(有挂猫腻)-哔哩哔哩1.哈糖大菠萝免...
详细透视!wepoker私人局... 详细透视!wepoker私人局辅助挂,微信微乐辅助免费,步骤教程(有挂技术)-哔哩哔哩该软件可以轻松...
有挂透视!wepoker钻石怎... 有挂透视!wepoker钻石怎么看底牌,微乐家乡自建房辅助app,妙计教程(今日头条)-哔哩哔哩1、...
解谜透视!wepoker私人局... 解谜透视!wepoker私人局辅助器怎么用,微乐陕西麻将破解,法门教程(确实有挂)-哔哩哔哩1、解谜...
分享透视!hhpoker德州牛... 分享透视!hhpoker德州牛仔视频,微信小程序微乐辅助器免费下载,妙计教程(有挂细节)-哔哩哔哩小...
解密透视!竞技联盟辅助插件,微... 解密透视!竞技联盟辅助插件,微乐安徽小程序辅助,机巧教程(有挂解密)-哔哩哔哩1、下载好竞技联盟辅助...
专业透视!德普之星透视免费,微... 专业透视!德普之星透视免费,微乐自建房辅助软件有哪些功能,指南教程(有挂分析)-哔哩哔哩1、在德普之...