当前位置:首页 » 《关注互联网》 » 正文

vue3实现面包屑-基础实现

0 人参与  2024年09月30日 18:40  分类 : 《关注互联网》  评论

点击全文阅读


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://m.zhangshiyu.com/post/166763.html

<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

最新文章

  • 完结文我在恐怖游戏开裁缝铺列表_完结文我在恐怖游戏开裁缝铺(林慕秋)
  • 全书免费谢清禾姜博诚_谢清禾姜博诚全书免费
  • 离婚后我收获真爱,前妻却快死了(秦落音陆轩),离婚后我收获真爱,前妻却快死了
  • 老公把上亿豪宅送养妹后,我把人和房都拆了(顾思思顾言洲)全书免费_(顾思思顾言洲)老公把上亿豪宅送养妹后,我把人和房都拆了后续(顾思思顾言洲)
  • 沈星悦傅时安_沈星悦傅时安
  • 离婚后,居然还能以旧换新?(陈汉李淼淼李思)全书浏览_离婚后,居然还能以旧换新?全书浏览
  • 完结文给女团主播狂刷百万反被骂穷逼,我反手送她队友出道列表_完结文给女团主播狂刷百万反被骂穷逼,我反手送她队友出道(秦薇)
  • 全书浏览老公将我第十个孩子送给情人后,我果断改嫁他绝嗣干爹(苏云遮盛炽)_老公将我第十个孩子送给情人后,我果断改嫁他绝嗣干爹(苏云遮盛炽)全书结局
  • 全文无边怨恨是她活下来的最大动力(江寒静顾榕赫)列表_全文无边怨恨是她活下来的最大动力
  • 全文爸爸死后,消失二十年的妈妈带着儿子回来跟我争家产(顾霆锋顾青卿)列表_全文爸爸死后,消失二十年的妈妈带着儿子回来跟我争家产
  • 霍晚清赵旭然_霍晚清赵旭然
  • 弟弟看的破茧时光沉淀后的深情相拥林悦苏然全书在线

    关于我们 | 我要投稿 | 免责申明

    Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1