vue3实现面包屑-基础实现

news/2024/12/22 1:22:41/

1.在默认路由router文件下新增两个额外的文件page:存放额外的路由列表,注意这里需要引入有router-view视图的页面,这里我是采用let Main = () => import("@v/layout/Main.vue");代码:

在page中使用:

2.dynamicAddRouter处理不匹配的路由和注册page路由表到router中

3.面包屑组件:

3.状态管理代码:

import router from '@/router'

import { ClassTag } from '#/index'

import { defineStore } from 'pinia'

import { inject } from 'vue'

import type { RouteLocationNormalizedLoaded } from 'vue-router'

export const useTagStores = defineStore('Tag', {

    state: () => ({

        tagList: [new ClassTag("/accountmanage/accountlist", "商户列表", "home")],//路由列表

        reload :inject("reload") as any

    }),

    actions: {

        // 添加

        pushTag(route: RouteLocationNormalizedLoaded, index: number = -1) {

            const { fullPath, meta, name } = route

            // 如果当前路由是redirect,则返回不添加标签页

            if ("redirect" === name) {

                return;

            }

            let openTags = this.tagList

            let findIndex = openTags.find((item: ClassTag) => item.fullPath == fullPath)

            if (!findIndex) {

                var i = index > -1 ? index : openTags.length

                openTags.splice(i, 0, new ClassTag(fullPath, meta.title as string, name as string))

            }

        },

        // 妙处,清空列表在添加避免将其他模块的路由增加进去

        settagList(route: RouteLocationNormalizedLoaded) {

            const { fullPath, meta, name } = route

            let openTags = this.tagList

            openTags.splice(0)

            openTags.splice(1, 1, new ClassTag(fullPath, meta.title as string, name as string))

        },

        // 点击跳转

        headerTab(index: number) {

            let tag = this.tagList[index]

            let route = router.currentRoute.value

            if (tag.fullPath != route.fullPath) {

                router.push(tag.fullPath);

            }

        },

        /**

         * 右键菜单功能

         */

        Command({ code, fullPath }: { code: number, fullPath: string }) {

            let openTags = this.tagList

            let route = router.currentRoute.value

            //点击标签页索引

            let index = openTags.findIndex((item) => item.fullPath == fullPath);

            //当前激活状态的标签页索引

            let activeIndex = openTags.findIndex((item) => item.fullPath === route.fullPath);

            switch (code) {

                case 1:

                    this.reload();

                    break;

                case 2://关闭左侧所有标签页

                    openTags.splice(0, index);

                    if (activeIndex != index||activeIndex <= index) {

                        router.push(openTags[0]?.fullPath);

                    }

                    break;

                case 3://关闭右侧所有标签页

                    // 删除右侧所有标签页

                    openTags.splice(index + 1);

                    // 如果当前页面被删除,显示右击菜单页

                    if (activeIndex > index) {

                        router.push(openTags[index].fullPath);

                    }

                    break;

                case 4:

                    this.removePath(fullPath)

                    break;

                case 5: //关闭所有标签页

                    openTags.splice(1);

                    router.push(openTags[0].fullPath);

                    break;

            }

        },

        // 删除

        removePath(fullPath: string) {

            let openTags = this.tagList

            let index = openTags.findIndex(item => item.fullPath === fullPath)

            if (-1 != index) {

                this.removeTab(index)

            }

        },

        removeTab(index: number) {

            let openTags = this.tagList

            let tag = openTags[index]

            // 获取当前路由信息

            let route = router.currentRoute.value

            // 如果当前路由的 fullPath 等于 tag 的 fullPath,则说明需要进行路由跳转

            if (route.fullPath == tag.fullPath) {

                // openTags[index + 1] || openTags[index - 1] 判断跳转到哪个路由(下一个或上一个),并将该路由的全路径赋值给 fullPath 变量

                let { fullPath } = openTags[index + 1] || openTags[index - 1];

                router.push(fullPath);

            }

            // 在 openTags 中删除指定下标的元素

            openTags.splice(index, 1)

        },

    },

    persist: true//开启持久化

})


http://www.ppmy.cn/news/1503591.html

相关文章

vscode+platformio开发小技巧

使用vscodeplatformio开发&#xff0c;具体安装配置文章很多&#xff0c;这里分享一些方便使用的小技巧&#xff0c;让使用体验在不增加学习成本的情况下更加丝滑。 1、配置依赖库 在使用vscode开发前&#xff0c;arduino环境遗留了一些库文件&#xff0c;这些第三方库可以通…

Spring-Ioc,Di,Bean

博客主页&#xff1a;音符犹如代码系列专栏&#xff1a;JavaWeb关注博主&#xff0c;后期持续更新系列文章如果有错误感谢请大家批评指出&#xff0c;及时修改感谢大家点赞&#x1f44d;收藏⭐评论✍ 目录 IOC DI Bean 在上一期我们给大家讲解了三层架构和分层解耦&#xff…

嵌入式学习Day19---Linux软件编程

目录 一、标准I/O 1.1.fseek 1.偏移量 2.实例 ​编辑 1.2.ftell 2.实例 ​编辑 二、文件I/O 2.1.打开文件 1.open 2.2.实例 2.2.读写文件 1.write 实例 ​编辑 2.read 实例 2.3.关闭文件 1.close 2.3.lseek 实例 三、标准I/O与文件I/O的区别 3.1.区别 四、其…

【软件建模与设计】-07-静态建模

目录 1、类之间关系 1.1、关联 1.1.1、关联的多重性 1.1.2、三元关联 1.1.3、一元关联 1.1.4、关联类 2、组合与聚合层次 2.1、组合 2.2、聚合 3、泛化/特化层次 4、约束 5、静态建模和UML 5.1、问题域的静态建模 6、系统上下文的静态建模 7、使用UML构造型对类…

PostgreSQL——查询扫描介绍

顺序扫描 概述 顺序扫描&#xff08;Sequential Scan&#xff09;是PostgreSQL中一种基本的数据检索方式&#xff0c;它通过按顺序读取表中的所有页面来查找满足查询条件的记录。这种方式不依赖于索引&#xff0c;因此在某些情况下可能是唯一的选择&#xff0c;尤其是当表没有…

轻松入门Linux—CentOS,直接拿捏 —/— <5>

一、Linux常用工具 1、tar打包命令详解 当 tar 命令用于打包操作时&#xff0c;该命令的基本格式为&#xff1a; tar [选项] 源文件或目录 常用选项&#xff1a; 1.1 打包文件 例如&#xff0c;我有几个文件&#xff0c;将他们打包成一个文件&#xff0c;以tar结尾的后缀名 …

C++ 列式内存布局数据存储格式 Arrow

Apache Arrow 优点 : 高性能数据处理&#xff1a; Arrow 使用列式内存布局&#xff0c;这特别适合于数据分析和查询操作&#xff0c;因为它允许对数据进行高效批量处理&#xff0c;减少CPU缓存未命中&#xff0c;从而提升处理速度。 零拷贝数据共享&#xff1a; Arrow …

Java中的BIO,NIO与操作系统IO模型的区分

Java中的IO模型 Java中的BIO&#xff0c;NIO&#xff0c;AIO概念可以是针对输入输出流&#xff0c;文件&#xff0c;和网络编程等其他IO操作的。 但是主要还是在网络编程通信过程中比较重要&#xff0c;因为很多情况网络编程需要它们来提供更好的性能。 所以本篇文章偏向于网络…