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

  • 进口消费税为什么一定要组价
  • 购买汽车的保健因素
  • 结算金额和付款金额
  • 工会经费的减免申请
  • 房地产企业在开盘前的销售费用是否可以在税前扣除
  • 通信费税前列支的标准和报销票据的要求
  • 公司租车怎么抵税
  • 固定资产清理后卡片如何处理
  • 税务局开收据的流程
  • 平行登记要求总账
  • 购入包装物
  • 企业纳税总额包含哪些
  • 营改增要交增值税吗
  • 核定经营额是一个季度还是一个月
  • 审计调账后企业怎么处理
  • 中药饮片加成率超的原因
  • 1697511073
  • 结转未交增值
  • 小微企业免税的会计分录怎么写
  • 购入办公桌椅怎样入账
  • 租赁合同法律风险
  • 季度成本分析报告
  • 单位办事人员
  • 母公司向子公司发行面值100万元、期限为三年
  • 以前年度损益调整借贷方向
  • mp3最早什么年代流行
  • 材料成本差异如何做账
  • 增值税如何在报表里填写
  • 房产税是什么意思,简单的回答
  • 发票开错抬头怎么进行税务处理?
  • 专项基金设立
  • 为公司垫付费用,怎么要回
  • vue ref获取元素高度
  • php时间戳转换成时间
  • next frame
  • 文心一言中国经济大讲堂
  • php忘记密码
  • 总公司与分公司合作协议范本
  • 工会收到单位拨款的会计分录
  • 培训费开票属于哪个征收明目
  • 帝国cms建站教程
  • mysql左连接查询 效率
  • SQL Server 2016 CTP2.2安装配置方法图文教程
  • 期权权利金的计算公式
  • 房产出租税率是多少
  • 财务费用应付利息
  • 实收资本印花税属于什么税目
  • 公司购买垃圾箱会计分录
  • 附加税多计提了怎么做分录
  • 查缴个人海外避税所得税
  • 工会经费为0是不用申报的?
  • 发工资四舍五入多了几块钱怎么办
  • 办公楼开始建造前专门借款的利息费用
  • 减免的增值税要交所得税吗
  • 管理不善造成的存货盘亏损失计入什么科目
  • 工资油补也要交税吗
  • 销售成本存在的问题
  • mysql内存占用一直增高不释放
  • mysql5.6解压版安装教程
  • sql语句重复
  • 该程序无法正常启动
  • ubuntu系统中如何安装WiFi驱动
  • windows 专业版10安装后文件会丢失嘛
  • 一键ghost的功能
  • ubuntu系统升级到18
  • centos怎么安装
  • 腾讯tp驱动
  • mini programes
  • Cocos2dx CrazyTetris 双线伪裁剪算面积 对于判断消除的思考(二)
  • unity ugui组件
  • 用javascript写简单网页
  • edittext获取焦点弹出键盘
  • python 异常处理方法
  • 国家税务局扬州 袁霞
  • 税控盘监控信息写盘失败时钟校准
  • 缴款单号怎么交学费
  • 河南省国家税务总局网站
  • 内蒙古税务局发票认证
  • 房产证加名字需要哪些手续和费用
  • 票据贴现的票据是什么
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设