gpt4 book ai didi

angular - 如何在 Angular 6 中使用 "routerLinkActive"和查询参数?

转载 作者:太空狗 更新时间:2023-10-29 17:46:04 24 4
gpt4 key购买 nike

我在 Angular 中遇到问题:我有三个链接,其中一个有查询参数(由于使用了解析器)。如果我单击第一个和第三个链接,则会设置 routerLinkActive。如果我单击第二个链接,routerLinkActive 也会设置。但是,如果我更改组件内的查询参数,routerLinkActive 将被取消设置。

所以,我需要忽略查询参数。但是它是如何工作的呢?谁能帮帮我?

这是我的简单代码:

<div class="col-12">
<ul class="nav nav-pills nav-justified">
<li class="nav-item">
<a
class="nav-link"
routerLink="/einstellungen/allgemein"
routerLinkActive="active">
Allgemein
</a>
</li>
<li class="nav-item">
<a
class="nav-link"
[routerLink]="['/einstellungen/kalender']"
[queryParams]="{branch: myBranches[0].id}"
routerLinkActive="active"
[routerLinkActiveOptions]="{exact: false}">
Kalender verwalten
</a>
</li>
<li class="nav-item">
<a
class="nav-link"
*ngIf="user.is_admin"
routerLink="/einstellungen/filialen"
routerLinkActive="active">
Filialen verwalten
</a>
</li>
</ul>
</div>

最佳答案

RouteLinkActive 仅适用于精确的查询参数。您可以尝试将 {exact: false} 作为 routerLinkActiveOptions 传递。如果那不起作用

您可以在 [class.active] 属性中调用函数。

<a class="nav-link" [routerLink]="['/einstellungen/kalender']" [queryParams]="{branch: myBranches[0].id}" [class.active]="isLinkActive('/my-link')">Kalender verwalten</a>

isLinkActive(url): boolean {
const queryParamsIndex = this.router.url.indexOf('?');
const baseUrl = queryParamsIndex === -1 ? this.router.url :
this.router.url.slice(0, queryParamsIndex);
return baseUrl === url;
}

关于angular - 如何在 Angular 6 中使用 "routerLinkActive"和查询参数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52037979/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com