Angular两个不同路径相同菜单项处于活动状态
创始人
2024-10-28 00:00:43
0

在Angular中,要实现两个不同路径下的相同菜单项处于活动状态,可以使用ActivatedRoute的属性来判断当前路由是否与菜单项的路径相匹配,并在模板中设置相应的CSS类来表示活动状态。

以下是一个示例代码:

首先,在菜单组件中,定义一个菜单项的数组,并使用ngFor指令生成菜单项:

  • {{ item.label }}

在组件的类中,定义菜单项的数组和当前路由路径的变量,并注入ActivatedRoute服务:

import { Component } from '@angular/core';
import { ActivatedRoute } from '@angular/router';

@Component({
  selector: 'app-menu',
  templateUrl: './menu.component.html',
  styleUrls: ['./menu.component.css']
})
export class MenuComponent {
  menuItems = [
    { label: 'Home', path: '/home' },
    { label: 'About', path: '/about' },
    { label: 'Contact', path: '/contact' }
  ];

  currentPath: string;

  constructor(private route: ActivatedRoute) {
    this.route.url.subscribe(url => {
      this.currentPath = url.join('/');
    });
  }

  isActive(path: string) {
    return this.currentPath === path;
  }
}

在isActive方法中,判断当前路由路径是否与菜单项的路径相匹配,如果相同,则返回true,表示活动状态。

最后,在菜单组件的CSS文件中,定义活动状态的样式:

.active {
  background-color: #ccc;
}

这样,当路由路径与菜单项的路径匹配时,相应的菜单项会被设置为活动状态,应用了活动状态的CSS样式。

相关内容

热门资讯

推荐攻略“wepoker系统发... >>您好:wepoker系统发牌规律软件加扣扣群确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用...
开挂辅助软件"wep... 大家好,今天小编来为大家解答wepoker透视功能下载这个问题咨询软件客服可以免费测试直接加微信(1...
普及知识“微扑克辅助期是干嘛的... 无需打开直接搜索加微信客服(136704302)咨询了解微扑克辅助期是干嘛的辅助器目前(微信:136...
开挂辅助插件"wer... 开挂辅助插件"werplan怎么透视"开挂(透视)辅助脚本(有挂总结);无需打开直接搜索打开薇:13...
总算明白“wepoker辅助透... >>您好:wepoker辅助透视教程确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的牌特别好...
开挂辅助平台"wpk... 开挂辅助平台"wpk透视辅助下载"开挂(透视)辅助工具(存在有挂);wpk透视辅助下载简单的透视挂控...
每日必看“wepoker辅助透... 您好,wepoker辅助透视教程这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】...
开挂辅助工具"wer... 开挂辅助工具"werplan怎么辅助"开挂(透视)辅助平台(有挂细节);无需打开直接搜索打开薇:13...
最新通报“wepoker透视脚... >>>您好:,软件加微信【添加136704302】确实是有挂的,很多玩家在这款游戏中打牌都会发现很多...
开挂辅助脚本"wep... 开挂辅助脚本"wepoker辅助器是真的吗"开挂(透视)辅助软件(有挂技巧);无需打开直接搜索打开薇...