当前位置: 首页 > article >正文

Angular菜单项激活状态保持

菜单项激活状态保持

  • 需求描述
    • 详细需求
  • 解决方案

需求描述

如果有个需求,让你实现一个导航栏,点击不同菜单,图表会有不同变化,页面刷新后,该菜单状态仍旧保持,实现方法如下:

例图,有点丑,轻喷
在这里插入图片描述

详细需求

比方说,我们点击列表二,出现列表二的数据,同时我们点击刷新后,出现的还是被选中的列表二而不是默认的列表一。

解决方案

主要使用Angular当中的路由管理,给每个菜单在父级路由下重新设置四个子路由。然后刷新后,在构造函数中用split切割当前路由,切割符为/,拿到当前路由查看最后一个路由是什么字符串,最后绑定那个字符串对应的菜单索引值。
本期用到的技术栈:Angular、Ts。

  1. 设置子路由:找到router.module.ts文件下组件位置,并加上代码:
children:[
{
path:'table1',
component:父级组件名,
canActivate: [RouterGuard]
},
{
path:'table2',
component:父级组件名,
canActivate: [RouterGuard]
}
]。。。

2.找到要添加路由条件的组件,导入router路由方法。且加到constructor构造中

 import { ActivatedRoute, Router } from '@angular/router';
 constructor(private router:Router)

3.找到切换菜单函数,加入跳转路由方法

this.router.navigate(['/xxx/xxx', encodeURI(value)]);

其中value就是我们保存的切换菜单路由值,如table1,table2等。
4.在初始化函数ngInit中切割路由,再用length对路由进行长度判断,最后调用长度-1的索引值,for循环判断是否和菜单数组arr的value相等,相等则把对应id值赋值给菜单切换索引值index。

let temp= String(window.location.hash).split("/");
let len=temp.length
for(let i=0;i<arr.length;i++){
	if(temp[len-1]==arr[i].value){
	this.index=arr[i].value
}
}

然后就实现了,导航栏再刷新后不会重置且对应数据依然存在。


http://www.kler.cn/a/134474.html

相关文章:

  • 简历_使用优化的Redis自增ID策略生成分布式环境下全局唯一ID,用于用户上传数据的命名以及多种ID的生成
  • TinyEngine v2.1版本发布:全新的区块方案和画布通信方案,打造更强力的可拓展低代码引擎
  • 浅谈云计算20 | OpenStack管理模块(下)
  • HCIP-VLAN-hybrid接口+DHCP实验
  • 网管平台(进阶篇):路由器的管理实践
  • 使用Newtonsoft.Json插件,打包至Windows平台显示不支持
  • milvus数据管理-压缩数据
  • Python 如何实现职责链设计模式?什么是职责链设计模式?Python 职责链设计模式示例代码
  • Clickhouse初认识
  • Android设置控件透明度
  • 2023.11.17 hadoop之HDFS进阶
  • 计算机毕业设计选题推荐-掌心办公微信小程序/安卓APP-项目实战
  • SpringBoot学习笔记-创建个人中心页面(上)
  • ZYNQ_project:test_fifo_255X8
  • 人工智能:科技的魔术师
  • Ultipa Transporter V4.3.22 即将发布,解锁更多易用功能!
  • 智慧环保:科技驱动下的环境保护新篇章
  • 概念理论类: TCP/IP、Http、Socket之间的区别
  • axios的原理及实现一个简易版axios
  • 基于 gin + websocket 即时通讯项目 (一、项目初始化)
  • SpringCloudAlibaba系列之Nacos服务注册与发现
  • 十倍增量的海外客户开发新方式来了!外贸企业可直接照做
  • 【ELK01】ELK简介以及ElasticSearch安装、ES客户端工具-Head安装、报错问题整理
  • 6 个问题搞懂 HTTPS 加密通信的原理与 HTTPS 通信安全协议
  • JPA整合Sqlite解决Dialect报错问题, 最新版Hibernate6
  • Spring cloud负载均衡@LoadBalanced LoadBalancerClient