位置: 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应用程序(使用微软必应需要哪些条件)

  • 四川健康码旅行熊猫怎么领(四川健康码旅行熊猫图片)

    四川健康码旅行熊猫怎么领(四川健康码旅行熊猫图片)

  • b站720p60什么意思(b站720p 60帧)

    b站720p60什么意思(b站720p 60帧)

  • oppofindx2pro支持多少w的快充(oppofindx2pro支持无线充电吗)

    oppofindx2pro支持多少w的快充(oppofindx2pro支持无线充电吗)

  • 抖音上那些配音视频是怎么做的(抖音上那些配音的视频都是怎么弄的)

    抖音上那些配音视频是怎么做的(抖音上那些配音的视频都是怎么弄的)

  • 小米手机上怎么给网络加密(小米手机上怎么改文件名称)

    小米手机上怎么给网络加密(小米手机上怎么改文件名称)

  • 腾讯会议一直叮咚响(腾讯会议一直叮一个手机)

    腾讯会议一直叮咚响(腾讯会议一直叮一个手机)

  • iphone6s基带是高通吗(iphone6splus基带)

    iphone6s基带是高通吗(iphone6splus基带)

  • 抖音橱窗商品分类填写什么(抖音橱窗商品分类怎么选)

    抖音橱窗商品分类填写什么(抖音橱窗商品分类怎么选)

  • 拼多多直播不小心点开了,可以删除吗(拼多多直播不小心点了举报,怎么撤回)

    拼多多直播不小心点开了,可以删除吗(拼多多直播不小心点了举报,怎么撤回)

  • 荣耀30怎么隐藏应用(荣耀30怎么隐藏游戏)

    荣耀30怎么隐藏应用(荣耀30怎么隐藏游戏)

  • 局域网ping不通网关(局域网ping不通ip地址的原因)

    局域网ping不通网关(局域网ping不通ip地址的原因)

  • 路由器上网账号和口令是什么(路由器上网账号是什么)

    路由器上网账号和口令是什么(路由器上网账号是什么)

  • 手机屏幕边上出现黄边怎么办(手机屏幕边上出现黑点)

    手机屏幕边上出现黄边怎么办(手机屏幕边上出现黑点)

  • 蓝牙耳机一个声音大一个声音小(蓝牙耳机一个声音特别小)

    蓝牙耳机一个声音大一个声音小(蓝牙耳机一个声音特别小)

  • promax和pro区别(promax和pro区别苹果13)

    promax和pro区别(promax和pro区别苹果13)

  • 苹果8p能升级ios13吗(苹果8p能升级ios14吗)

    苹果8p能升级ios13吗(苹果8p能升级ios14吗)

  • 苹果手机怎么下载音乐(苹果手机怎么下载来电铃声)

    苹果手机怎么下载音乐(苹果手机怎么下载来电铃声)

  • 台式电脑怎么看wifi密码(台式电脑怎么看主板型号)

    台式电脑怎么看wifi密码(台式电脑怎么看主板型号)

  • 手机磨砂膜的好处(手机磨砂膜的好处是什么)

    手机磨砂膜的好处(手机磨砂膜的好处是什么)

  • 抖音怎么取消显示年龄(抖音怎么取消显示买过的店)

    抖音怎么取消显示年龄(抖音怎么取消显示买过的店)

  • word怎么设置每页几行(word怎么设置每行字数)

    word怎么设置每页几行(word怎么设置每行字数)

  • 苹果11夜景模式怎么开(苹果11夜景模式怎么拍视频)

    苹果11夜景模式怎么开(苹果11夜景模式怎么拍视频)

  • 如何知道被微信群踢了(如何知道被微信群拉黑)

    如何知道被微信群踢了(如何知道被微信群拉黑)

  • vivox20可以单换外屏吗(vivo x20可以换电池吗)

    vivox20可以单换外屏吗(vivo x20可以换电池吗)

  • 微信当前系统处于通话状态怎么关(微信当前系统处于通话状态怎么关目前仅可调节通话音量)

    微信当前系统处于通话状态怎么关(微信当前系统处于通话状态怎么关目前仅可调节通话音量)

  • 手机qq怎么取消自动回复(手机qq怎么取消频道)

    手机qq怎么取消自动回复(手机qq怎么取消频道)

  • IE总是阻止页面内容(ie浏览器阻止)

    IE总是阻止页面内容(ie浏览器阻止)

  • 餐饮发票公司怎么抵税
  • 税收成本包括哪些
  • 为什么增值税不计入营业税金及附加
  • 通用机打发票内容可以随便写吗
  • 椅子坐垫有用吗
  • 税务系统重置密码
  • 做网站的费用会计分录
  • 测试费用
  • 私车公用报销油费
  • 本年利润期末一般有余额吗
  • 发票领回来了怎么读入发票
  • 转业士官自谋职业
  • 购买办公用品并分发有关部门会计分录
  • 混合销售行为如何界定
  • 单位购买食品饮料的进项税可以抵扣吗?
  • 购买固定资产的进口关税
  • 物业服务合同印花算什么类型
  • etc预付卡发票能不能报销
  • 买车购置税为什么除11.3
  • 服务的进项税
  • 股权转让涉及的印花税
  • 牛奶的增值税普通发票
  • 酒店装修费用会计处理
  • 高技术制造企业
  • 职工养老金怎么交费
  • 企业支付微信认证怎么弄
  • win都是10 怎么办
  • 生育津贴报销需要准生证吗
  • 各种linux
  • 鸿蒙系统怎么设置导航键
  • php mb_convert_encoding
  • 汽车修理厂如何做账
  • 常见的财务报表分析方法有多选题
  • 无限极分类mysql
  • 长期借款的会计处理例题
  • vue的后端
  • zip命令详解
  • 建筑企业增值税税率是多少
  • 工资表中可以出现减号的情况吗
  • 被投资企业清算,长期股权投资处理
  • 帝国cms使用redis
  • sql 自定义字段
  • 劳务发票进什么科目
  • 个体工商户要做账报税吗
  • 无法偿付的应付账款计入什么科目政府会计
  • 白酒消费税最低计税价格核定范围包括
  • 建账盘存库存商品的分录
  • 造价咨询费计入固定资产吗
  • 销售样品分录
  • 政府代建工程
  • 物流辅助服务属于
  • 招标代理专家库合法吗
  • 到银行货款现金怎么货
  • 没有申报未开票收入怎么办
  • 一年以内到期的长期借款属于
  • 淘宝电商怎么做账
  • 商业企业购入商品
  • 购入固定资产入账会计处理
  • 增值税科目设置及科目号
  • ubuntu没有wlan0
  • freebsd使用
  • win8有几种版本
  • ubuntu安装指南
  • ubuntu必备软件10款
  • win7winxp双系统怎么装
  • qcwlicon.exe - qcwlicon是什么进程 有何作用
  • 应该怎么修复
  • linux三种用户权限
  • xcode配置opencv
  • python 压缩gz
  • 手把手教你把币从交易所提到钱包
  • python网络编程从入门到精通
  • 陕西税务局稽查处处长
  • 朝阳税务总局
  • 报销的费用交印花税吗
  • 怎样在中国税务用手机交社保
  • 税务总局着装管理办法
  • 新车购置税最低多少钱
  • 契税和房产税是一回事吗
  • 出口退税正式申报资料上传
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设