gpt4 book ai didi

Angular 路由器链接事件嵌套菜单

转载 作者:太空狗 更新时间:2023-10-29 18:00:31 25 4
gpt4 key购买 nike

我正在尝试制作一个带有 Angular 路线的嵌套菜单。

我需要的是将类应用于嵌套路由(如果它处于事件状态)并将类应用于父组件(如果其子组件处于事件状态)。

我如何实现这一点?现在我正在做递归菜单构建,以便在我需要多层嵌套时易于使用。

组件.html

<a (click)="toggleActive()" [class.active]="isActive" [routerLink]="menuItem.link" *ngIf="menuItem.link; else noLink">
<i *ngIf="menuItem.faClass" class="fa fa-{{menuItem.faClass}}"></i>
{{menuItem.name}} <span *ngIf="menuItem.children && menuItem.children.length > 0" class="fa fa-chevron-down"></span>
</a>

<ng-container *ngIf="menuItem.children && menuItem.children.length > 0">
<ul class="nav child_menu" [class.active]="isActive" routerLinkActive="active"
*ngFor="let item of menuItem.children">
<li menu-item [menuItem]="item" (checkActive)="updateActiveState()"></li>
</ul>
</ng-container>

<ng-template #noLink>
<a (click)="toggleActive()" [class.active]="isActive">
<i *ngIf="menuItem.faClass" class="fa fa-{{menuItem.faClass}}"></i>
{{menuItem.name}} <span *ngIf="menuItem.children && menuItem.children.length > 0" class="fa fa-chevron-down"></span>
</a>
</ng-template>

组件.ts

@Component({
selector: '[menu-item]',
templateUrl: './menu-item.component.html',
styleUrls: ['./menu-item.component.scss'],
host: {
'[class.active]': 'hostActive && isActive',
'[class.active-sm]': 'hostActiveSm && isActive'
}
})
export class MenuItemComponent implements OnInit, AfterViewInit, OnChanges {

public menuSize;
public isActive = false;

@Input() menuItem: MenuItem;
@Output() checkActive: EventEmitter<void> = new EventEmitter<void>();
@ViewChild(MenuItemComponent) menuComponent: MenuItemComponent;

private hostActive = true;
private hostActiveSm = false;

@HostBinding('class') hostClass = this.hostActive && this.isActive ? 'active' : this.hostActiveSm && this.isActive ? 'active-sm' : '';

constructor(
private router: Router,
private uss: UiStateService,
) {
}

ngOnInit() {
this.uss.menuSubject.subscribe(msg => {
this.menuSize = msg;
if (this.menuSize === MenuSizes.sm) {
this.hostActive = false;
this.hostActiveSm = true;
} else {
this.hostActive = true;
this.hostActiveSm = false;
}
this.updateActiveState();
});

this.router.events.subscribe((e: Event) => {
if (e instanceof NavigationEnd) {
this.updateActiveState();
}
});
}

ngOnChanges() {
}

ngAfterViewInit() {
this.updateActiveState();
}

public toggleActive(): void {
this.isActive = !this.isActive;
// if (this.menuComponent) {
// this.menuComponent.isActive = true;
// }
}

private updateActiveState(): void {
// reset previous state
this.isActive = false;
if (this.menuComponent) {
this.menuComponent.isActive = false;
}

// Check state of item with no els
const url = this.router.url;
console.log('URL', url, 'Menu link', this.menuItem.link);
console.log(url.match('/' + this.menuItem.link + '$/'));
if (this.menuItem && this.menuItem.link && url.match('/' + this.menuItem.link + '$/')) {
this.isActive = true;
this.checkActive.emit();
}

if (this.menuComponent) {
console.log('Menu component');
console.log(this.menuComponent, this.menuComponent.menuItem.link);
this.isActive = true;
}
}

}

有没有办法从一个组件中知道它的路由是否处于事件状态?诀窍是我使用的是 [routerLink] 而不是 routerLink 以便我可以将 . 作为指向根页面的链接传递。

更新

我能重新创造的最好的stackblitz尝试访问“Dasboard”。它应该向父 li 添加一个“事件”类。如果您自己添加它,您会在它的元素上看到应用的类,并在右侧看到一个彩色条。

最佳答案

也许你可以尝试在任何组件中访问 ActivatedRoute

import { Router, ActivatedRoute} from '@angular/router';    

constructor(private router: Router, private activatedRoute:ActivatedRoute) {
console.log(activatedRoute.snapshot.url) // array of states
console.log(activatedRoute.snapshot.url[0].path)
}

希望对您有所帮助!

关于 Angular 路由器链接事件嵌套菜单,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53299952/

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