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

  • puk码忘记了怎么解锁(puk码)(puk码忘记了怎么解锁 中国联通)

    puk码忘记了怎么解锁(puk码)(puk码忘记了怎么解锁 中国联通)

  • faceu控雨怎么玩(控雨特效在哪里找的)

    faceu控雨怎么玩(控雨特效在哪里找的)

  • 我的宁夏健康码黄色怎么变成绿色(我的宁夏健康码怎么切换另一个人)

    我的宁夏健康码黄色怎么变成绿色(我的宁夏健康码怎么切换另一个人)

  • 苹果拉黑后怎么看拦截信息记录(苹果拉黑后怎么看拦截电话时间)

    苹果拉黑后怎么看拦截信息记录(苹果拉黑后怎么看拦截电话时间)

  • ppt里怎么添加视频

    ppt里怎么添加视频

  • 交管12123找回密码数据未知(交管12123找回密码收不到验证码)

    交管12123找回密码数据未知(交管12123找回密码收不到验证码)

  • 华为能不能登两个微信(华为手机能不能登录两个华为账号)

    华为能不能登两个微信(华为手机能不能登录两个华为账号)

  • 什么手机视频聊天有美颜功能(什么手机视频聊天不会迷糊的)

    什么手机视频聊天有美颜功能(什么手机视频聊天不会迷糊的)

  • 电话被拉黑了打过去会听到什么(电话被拉黑了打face time可以吗)

    电话被拉黑了打过去会听到什么(电话被拉黑了打face time可以吗)

  • 一个手机号可以注册几个支付宝(一个手机号可以注册几个淘宝账号)

    一个手机号可以注册几个支付宝(一个手机号可以注册几个淘宝账号)

  • 退款催促卖家处理按钮在哪(催买家退货)

    退款催促卖家处理按钮在哪(催买家退货)

  • 如何冻结表格前几列(如何冻结表格前四行)

    如何冻结表格前几列(如何冻结表格前四行)

  • iponeqq表情包怎么删除(苹果手机qq表情)

    iponeqq表情包怎么删除(苹果手机qq表情)

  • ps怎么新建通道

    ps怎么新建通道

  • 苹果11pro几个卡(苹果11pro几张电话卡)

    苹果11pro几个卡(苹果11pro几张电话卡)

  • 魅族手机远程管理怎么用(魅族手机远程操作)

    魅族手机远程管理怎么用(魅族手机远程操作)

  •  word文档改不了内容怎么办(word文档改不了输入法)

    word文档改不了内容怎么办(word文档改不了输入法)

  • 手机用了三年还能用吗(手机用了三年还不卡)

    手机用了三年还能用吗(手机用了三年还不卡)

  • tcpudp区别是什么(tcpipudp区别)

    tcpudp区别是什么(tcpipudp区别)

  • led灯坏了怎么换(客厅led灯坏了怎么换)

    led灯坏了怎么换(客厅led灯坏了怎么换)

  • 苹果电脑怎么切换搜狗输入法(苹果电脑怎么切换成windows模式)

    苹果电脑怎么切换搜狗输入法(苹果电脑怎么切换成windows模式)

  • 零钱明细怎么单个删除(零钱明细怎么单独删除)

    零钱明细怎么单个删除(零钱明细怎么单独删除)

  • 微软输入法突然不显示选字框解决方法(微软输入法突然变成繁体字怎么改回来)

    微软输入法突然不显示选字框解决方法(微软输入法突然变成繁体字怎么改回来)

  • 家常煲汤500例的做法(图文)(家常煲汤500例的做法窍门)

    家常煲汤500例的做法(图文)(家常煲汤500例的做法窍门)

  • 详解 HttpServletResponse

    详解 HttpServletResponse

  • 同一商品税收分类编码不一样
  • 预交所得税分录怎么写
  • 建筑业固定资产折旧费用科目是什么
  • 附加税有哪些?
  • 增值税发票系统怎么读入发票
  • 合同解除的效力民法典
  • 出口退税进项税额转出怎么申报
  • 企业所得税几大税种
  • 资产负债表季报本月数怎么填
  • 油费补贴计入什么科目
  • 无发票入账违反哪条法律
  • 维修企业主营项目有哪些
  • 清洗汽车的目的
  • 跨年发票是否可以报销 审计
  • 加计扣除退回的所得税怎么做账
  • 购入债券计入什么科目
  • 个人给单位干的小工程需代扣个税吗?
  • 开发票时怎么修改税收分类简称?
  • 小型连锁药店需要报国税吗?
  • 土地增值税计算题及答案解析
  • 员工工伤单位垫付
  • 个人出租房屋交税如何计算
  • 企业未代扣代缴个税
  • 财务人员工资计入管理费用还是财务费用
  • 委托进口代理协议
  • 诉讼费计入哪里
  • windows 10如何使用
  • 腾讯电脑管家中的软件市场打不开
  • 固定资产清理净值是什么意思
  • 8款应用
  • 没按时报税罚款多少
  • php ladp
  • php魔术常量有多少
  • 小微企业认定标准时间
  • yolo系列算法全家桶
  • 【原创】基于JavaWeb的医院预约挂号系统(医院挂号管理系统毕业设计)
  • echarts快速上手
  • 残保金申报缴纳时间
  • java桥接模式的应用场景
  • 勾选发票提交后如何
  • 客户倒闭预收款怎么处理
  • 净收入是营业收入吗
  • 企业合并财务报表项目有哪些
  • 销售费用和管理费用占比多少合理
  • 小规模纳税人税金账务处理
  • 请问在accessdemo1
  • 企业出售自用房产增值税
  • 什么是全面一次性奖金
  • 采购未到票如何入账
  • 其他应收款和其他应付款可以通用吗
  • 财务费用如何调到筹资费用
  • 中标服务费可以税前扣除吗
  • 两个企业同一个法人
  • 车辆违章处理有什么规定
  • 退货回去需要把原包装保留吗
  • 公对公转账后对方拒绝开发票
  • 上月其他应付款本月怎么调回来
  • 长期待摊费用包括增值税吗
  • 银行回单中借贷表示什么意思
  • sql server本地服务器地址如何查看
  • 微软9月30日将发行股票
  • win7系统对拷的方法
  • win10桌面上图标
  • win10怎么去掉
  • win7如何打开远程桌面连接
  • onenotewindows10
  • macbookpro移到废纸篓快捷键
  • linux命令行怎么用
  • 观察者模式指令
  • opengl clamp
  • linux那么多命令怎么记
  • 用户体验ui
  • nodejs爬虫技术
  • unity后期
  • js颜色表
  • 广州市地方税务局规费服务中心
  • 以房产作价投资入股如何处理
  • 武汉市房产证契税 2023
  • 如何在国税网查看社保人员信息
  • 南京税务事务所排行
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设