位置: IT常识 - 正文

vue实现动态路由添加(简单无废话版本)(vue动态路由是什么)

编辑:rootadmin
vue实现动态路由添加(简单无废话版本)

推荐整理分享vue实现动态路由添加(简单无废话版本)(vue动态路由是什么),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue动态路由与静态路由的区别,vue实现动态路由菜单,vue动态路由传参,vue动态路由三种方法,vue实现动态路由跳转,vue实现动态路由的方法,vue实现动态路由跳转,vue实现动态路由菜单,内容如对您有帮助,希望把文章链接给更多的朋友!

最近练习vue的项目,有关于后台管理系统的动态添加路由部分,根据思路实现了基本的功能,在这里记录一下,等后面学习后在进行优化。

这里只是记录我个人最后实现的思路,本人由于是初学者,可能思路和代码有不正确地方,还求多见谅。也请能不吝赐教,一同进步。

一 . 封装一个处理生产路由的函数vue实现动态路由添加(简单无废话版本)(vue动态路由是什么)

我们可以封装一个函数,这个函数专门用来帮助我们生产最后添加到路由中的路由对象。

//map-menu.js //动态添加路由const modules = import.meta.glob('../views/*/*.vue') //vite中获取组件文件的方法export function mapMenu(navList) {//navList 传入后台接口返回的路由列表 //最终动态添加路由返回数组 const routerList = [] for (const key of navList) { routerList.push({ path: `/${key.nUrl.split('/')[2]}`, name: `${key.nUrl.split('/')[2].toUpperCase()}`, component: modules[`..${key.nUrl}`] }) } return routerList}

注意:这里需要大家自己根据自己需要的情况进行处理,因为后端接口传递过来的数据不同,所以你需要根据情况将path,name,component这三个获取出来并最终转换成你需要的。

二. vuex中进行调用

我们封装好了一个函数,接下来我们就需要调用来帮助我们动态生产路由,但是有一个问题来了,我们需要何时来进行动态生成路由。 这里我个人理解是:1.在用户进行登录后进行动态生产路由,将用户的菜单生成出来,并保存起来。 2. 就是在页面刷新时候我们也需要动态生成路由,因为刷新页面路由会刷新,不再次进行动态生成就是丢失,这里我们可以和对vuex初始化一起进行。

// vuex中的user.js模块//动态添加路由import { mapMenu } from '@/util/map-menu.js' //前面封装的函数 state: { userNav: [] }, mutations: { changeUserNav(state, userNav) { state.userNav = userNav //动态添加路由 mapMenu(userNav).forEach((route) => { router.addRoute(route)//动态添加路由 }) } }, actions: { async requestUserNav({ commit }) { const navList = await getRolesNavRequest() commit('changeUserNav', navList) cache.setCache('jxcms-userNav', navList) }}

这样我们就定义好了,只需要调用store.dispatch('requestUserNav') 就可以动态生成路由。另外,因为vue-router4.0中将 router.addRoutes方法废除了,所以我们只能使用 router.addRoute 循环添加所有的路由。

三,最终完成动态添加路由

前面我们说过了,我们动态添加路由的时机就是二个,初始化和登录时候,所以我们现在就完成最后的部分。

// vuex中的user.js模块//动态添加路由import { mapMenu } from '@/util/map-menu.js' //前面封装的函数 state: { ... }, mutations: { ... }, actions: { async loginUser({ dispatch, commit }, info) { const loginRes = await loginUser(info) if (loginRes.uName) { if (!cache.getCache('jxcms-token')) { ElMessage({ message: '登录成功!', type: 'success' }) } commit('changeUser', loginRes) //本地存储 cache.setCache('jxcms-user', loginRes) dispatch('requestUserNav')//执行动态生成路由 router.push('/roles') cache.setCache('jxcms-token', loginRes.token) } else { ElMessage({ message: '登录失败', type: 'error' }) } }}

这里我们完成第一个动态添加路由的时机,登录成功时候,进行动态路由添加。

// vuex中的根模块 index.js actions: { initializationData({ dispatch, commit }) {//vuex初始化函数 const navList = cache.getCache('jxcms-userNav') commit('changeUserNav', navList)//动态生成路由 //要用同步的 const user = cache.getCache('jxcms-user') commit('changeUser', user) } }, modules: { user, nav, dept, roles }// main.js//初始化store.dispatch('initializationData')

这里我们完成了动态生成路由的第二个时机:刷新页面时,初始化时候进行动态路由生成. 因为刷新页面时候用户可能是登录状态,这样我们就不能通过登录成功来触发动态路由添加,就需要我们主动进行动态路由生成,在初始化时候,获取到本地存储的菜单信息,如果用户没有登录,本地的菜单信息会被清除。 另外,这里我使用的是commit来提交mutations,而不是actions函数,这是因为我在测试过程中发现,如果我使用actions,那么我在进入路由页面前,路由并没有创建成功,会报错,而使用mutations,因为是同步的,所以不会出现这个情况。这个问题后面如果找到解决办法,会重新进行修改。

本文链接地址:https://www.jiuchutong.com/zhishi/300833.html 转载请保留说明!

上一篇:Three.js教程:材质效果(three.js 入门)

下一篇:使用微软新必应(New Bing)AI机器人生成树莓派Pico W开发板MicroPython应用程序(使用微软必应需要哪些条件)

  • 微信怎么看bin图纸(怎么看微信所有图片)

    微信怎么看bin图纸(怎么看微信所有图片)

  • 拼多多在日历上的日程怎么取消(拼多多那个日历怎么弄掉)

    拼多多在日历上的日程怎么取消(拼多多那个日历怎么弄掉)

  • 荣耀x10max如何设置解锁(荣耀x10max如何设置自定义充电电量)

    荣耀x10max如何设置解锁(荣耀x10max如何设置自定义充电电量)

  • 程序设计的主要内容是算法和(程序设计的主要目标有)

    程序设计的主要内容是算法和(程序设计的主要目标有)

  • 快手邀请新用户的奖励可以提现吗(快手邀请新用户邀请码在哪里填)

    快手邀请新用户的奖励可以提现吗(快手邀请新用户邀请码在哪里填)

  • 手机响但是没有看见有什么通知(手机响但是没有铃声)

    手机响但是没有看见有什么通知(手机响但是没有铃声)

  • 华为手机文字怎么设置(华为手机文字怎么换成中文)

    华为手机文字怎么设置(华为手机文字怎么换成中文)

  • vivo系统更新在哪里找(vivo系统最新版本)

    vivo系统更新在哪里找(vivo系统最新版本)

  • 苹果升级13后蓝牙耳机连不上(iphone 13蓝)

    苹果升级13后蓝牙耳机连不上(iphone 13蓝)

  • 淘宝店铺装修分为哪几个模块(淘宝店铺装修分为几部分)

    淘宝店铺装修分为哪几个模块(淘宝店铺装修分为几部分)

  • 华为p40怎么返回上一步(华为p40怎么返回上一层)

    华为p40怎么返回上一步(华为p40怎么返回上一层)

  • 手机ld怎么查(手机ld怎么查定位)

    手机ld怎么查(手机ld怎么查定位)

  • 抖音撤回消息怎么删除(抖音撤回消息怎么能看到)

    抖音撤回消息怎么删除(抖音撤回消息怎么能看到)

  • oppo手机关不了机一直亮着怎么回事(oppo手机关不了屏幕解决方法)

    oppo手机关不了机一直亮着怎么回事(oppo手机关不了屏幕解决方法)

  • 电池健康多少该换了(电池健康度多少需要换电池)

    电池健康多少该换了(电池健康度多少需要换电池)

  • vivo手机越来越卡怎么解决办法(vivo手机越来越烫怎么回事)

    vivo手机越来越卡怎么解决办法(vivo手机越来越烫怎么回事)

  • miui10能解决4g断流问题吗(小米10双4g断流)

    miui10能解决4g断流问题吗(小米10双4g断流)

  • excel分析工具库在哪里(excel分析工具库加载不出来)

    excel分析工具库在哪里(excel分析工具库加载不出来)

  • iphone11如何打开飞行模式(iphone11如何打开数据漫游)

    iphone11如何打开飞行模式(iphone11如何打开数据漫游)

  • vue怎么设置自由时间(vue怎么设置自定义指令)

    vue怎么设置自由时间(vue怎么设置自定义指令)

  • 如何关闭快手的青少年模式(如何关闭快手的免密支付)

    如何关闭快手的青少年模式(如何关闭快手的免密支付)

  • 苹果11只能单卡吗(苹果只能单卡是假的吗)

    苹果11只能单卡吗(苹果只能单卡是假的吗)

  • 华为al00是什么型号(华为al00是什么系列)

    华为al00是什么型号(华为al00是什么系列)

  • qq附近的人关注失败(qq附近的人关注对方有提示吗)

    qq附近的人关注失败(qq附近的人关注对方有提示吗)

  • 苹果64g和256g的区别

    苹果64g和256g的区别

  • Vue中实现自定义excel下载(vue自定义dialog)

    Vue中实现自定义excel下载(vue自定义dialog)

  • 职工享受工伤津贴的条件
  • 民营医院一般纳税人帐务处理视频税收风险
  • 如何查询增值税申报表
  • 企业如何提供准确的会计信息
  • 分公司预缴企业所得税总公司可以抵扣吗
  • 工会经费能零申报,可以计提工会经费吗
  • 票面3个点的增值税发票是交几个点的税金
  • 企业劳务外包员工有五险一金吗
  • 建筑企业发生分包业务如何确认收入
  • 个税手续费返还政策最新规定2023
  • 住房按揭贷款贷后检查内容
  • 微信公众订阅号怎么注册
  • 异地工程要预缴环境税款吗
  • 财务软件里面可以修改吗
  • 吸收合并后被合并的公司
  • 苹果mac切换桌面快捷键
  • 企业支付工商年费怎么查
  • vue城市列表插件
  • 非正常损失的进项税额如何计算
  • 自产自用产品的会计处理
  • 车辆哪些费用计税
  • linux tr
  • 补充养老保险税收规定扣除率
  • 传媒改革
  • 苹果发布macOS13.5开发者预览版
  • win7纯净版系统官网
  • cpu版本的pytorch可以运行LSgan嘛
  • 承包安装工程怎么报价
  • 外籍人员一次性奖金
  • 加利福尼亚湾在哪
  • 扣税的账户是基本户还有一般户
  • 小规模纳税人增值税税率
  • 在建工程怎么填
  • 已付款收货未收到发票怎么做账
  • 租房没有合同编号可以提取公积金吗
  • 小规模纳税人免征增值税的账务处理
  • dubbo dubbox
  • 资产负债表日后至财务报告批准报出日之间
  • 无法支付的应付账款转作营业外收入
  • 商业保险 抵扣个税
  • 发票金额是含税价还是不含税价
  • 汇算清缴补交的所得税怎么记帐
  • 直接材料成本总差异怎么算
  • 公司销售红酒需要什么资质
  • 预付款已经开了发票未到货要怎么做账
  • 对外付汇代扣代缴所得税
  • 收到赞助费如何开发票
  • 新办企业在建期间账务处理
  • 工作经费是什么
  • 货物出去没有出口报关可以补吗
  • 车辆购置税的会计科目怎么写
  • 资产处置损益计入利润表哪个项目
  • 银行承兑汇票去哪个银行承兑
  • 收到上年度企业所得税退税怎么做账
  • 固定资产盘点表excel
  • sql行列转换方式
  • Win7笔记本怎么连接wifi
  • ubuntu wine安装的软件怎么运行
  • Linux操作系统分为
  • OS X10.10.5 Yosemite beta2发布 os x10.10.5yosemite beta2官网下载地址
  • linux操作系统安装包
  • csrsyncmlserver.exe是什么文件
  • 两种方法解决一半模型的问题
  • win8 侧边栏
  • win7旗舰版显示不全屏
  • jquery示例
  • jqgrid动态生成表头
  • 低端显卡n卡设置
  • javascript 函数定义
  • JavaScript—window对象使用示例
  • linux命令批量执行
  • js字符串编码解码
  • unity 子弹效果 粒子
  • .net 迭代器
  • shell脚本中实现rm -fr !(file1)
  • python的queue
  • android synchronized
  • jquery ui draggable
  • 第三届一带一国际高峰论坛
  • 杭州电子税务局注册流程
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设