多路径来源页面导航高亮以及面包屑导航修改

简介: 多路径来源页面导航高亮以及面包屑导航修改

问题缘由


这个问题比较普遍,原因是业务方面对产品进行多维度的划分(或者对产品进行归档、打标签、收藏等等),反应在前端方面就是同一个页面可以有不同的入口(产品目录结构划分)


干说不如举个例子:


  1. “活期储蓄”产品属于负债类理财产品(导航菜单)


  1. 关注“活期储蓄”产品


  1. 在“我的关注”菜单里也存在“活期储蓄”产品


从上面的描述中不难发现,“活期储蓄”产品既可以从“负债类理财产品”菜单进入,也可以从“我的关注”菜单进入。


这就带来了两个问题:


  1. 当进入“活期储蓄”产品详情页面的时候,高亮哪个导航菜单


  1. 当进入“活期储蓄”产品详情页面的时候,面包屑导航怎么显示


从用户角度来说自然是我从哪里点进去的就高亮哪个菜单,面包屑也真实的反应“来源路径”


技术背景


项目采用的技术: Vue,Element UI,vue-router


采用的 element ui 的 导航组件和面包屑组件。


面包屑是借助 vue-router 的 matched 方法 匹配到的路由对象数据注入ui组件实现的


解决问题


  • 如果可以从后端数据上进行处理当然更好,现实是没有如果。


  • 前端处理,分别针对导高亮和面包屑处理


思路分析


  1. 在进入详情页面的行为中增加标记(我使用 sessionStorage 标记,标记信息包括路径path、title,path用于高亮导航,title用于面包屑展示)


  1. 在离开详情页的时候移除标记(通过路由守卫实现,目的是标记不会带来别的副作用)


  1. 根据标记修正菜单高亮、面包屑展示


代码实现


分析完之后发现写代码就跟玩一样,没有什么技术含量,就不贴代码了


有一点需要注意:


在上面思路分析中,当进入详情页,刷新页面,可能会存在时序问题,具体就是面包屑组件里标记信息不能及时同步,这里我采用的是在data上面定义属性signTitle承接sessionStorage,然后在 computed 里面以signTitle为源数据得到最新的标记信息


可以使用全局状态管理方式替代sessionStorage,状态持久化就可以了

目录
相关文章
远程服务器返回错误(530)未登录 C# Ftp
    C#试图登录Ftp服务器时,报错“远程服务器返回错误(530)未登录”。     这是一个什么原因引起的呢? private void ConnectFTP() {         this.
7812 0
|
传感器 机器人 Linux
Linux驱动基础(HC-SR04超声波模块)
Linux驱动基础(HC-SR04超声波模块)
385 0
|
Android开发
Android面试高频知识点(1) 图解 Android 事件分发机制
在Android开发中,事件分发机制是一块Android比较重要的知识体系,了解并熟悉整套的分发机制有助于更好的分析各种点击滑动失效问题,更好去扩展控件的事件功能和开发自定义控件,同时事件分发机制也是Android面试必问考点之一,如果你能把下面的一些事件分发图当场画出来肯定加分不少。废话不多说,总结一句:事件分发机制很重要。
555 9
|
SQL 存储 关系型数据库
关系型数据库sqlserver的alter语句
【8月更文挑战第5天】
497 4
|
存储 Kubernetes Go
Go语言项目组织架构
Go语言项目组织架构
|
SQL Prometheus 监控
实时计算 Flink版产品使用问题之作业频繁重启该如何处理
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
SQL 关系型数据库 MySQL
实时计算 Flink版产品使用问题之如何指定从特定的binlog位置或最新的binlog位置开始读取数据
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
存储 安全 测试技术
容器安全是什么?
容器安全是什么?
|
应用服务中间件 网络安全 开发工具
利用 KMS 对文本信息进行签名验签实践
通过阿里云的KMS产品针对文件或者证书文件进行签名验签,可以有效解决攻击者针对敏感文件、重要文件在传输过程中被篡改,其次可以实现证书双向认证过程中的证书合法性校验,真正做到传输链路安全。
894 1
|
存储 达摩院 调度
「达摩院MindOpt」优化FlowShop流水线作业排班问题
在企业在面临大量多样化的生产任务时,如何合理地安排流水线作业以提高生产效率及确保交货期成为了一个重要的问题。
「达摩院MindOpt」优化FlowShop流水线作业排班问题

热门文章

最新文章