位置: IT常识 - 正文

若依:如何去掉首页,设置登录后跳转到第一个路由菜单(怎么样去掉)

编辑:rootadmin
若依:如何去掉首页,设置登录后跳转到第一个路由菜单

推荐整理分享若依:如何去掉首页,设置登录后跳转到第一个路由菜单(怎么样去掉),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:怎么去掉啊?,怎么有效的去掉,怎么去掉啊?,怎么有效的去掉,怎么有效的去掉,若依如何去掉首页菜单,去掉/n,如何去掉?,内容如对您有帮助,希望把文章链接给更多的朋友!

若依系统是一个很好用的,开源的前端后台管理系统。

最近公司有一个需求,需要把默认的首页隐藏,登录后直接跳转到路由菜单返回的第一个页面。

查找了不少资料,但是都没有实际的解决方案。

 不过最好自己还是实现了这个功能。

步骤如下:

1、首先应当找到项目里面,指定跳转到之前默认首页的路由。即'/index'

2、项目里面找到了几处,页面路径如下:

src/permission.js src/store/permission.js src/router/index.js src/utils/request.js src/system/user/profile/resetPwd.vue src/system/user/profile/userInfo.vue src/layout/components/Topbar.vue

1)  src/permission.js 需要修改的地方,

当登录之后,token的情况:

1.1) 这里  to.path=== '/login'   判断,当登录之后,但你想跳到登录页。那系统会跳到路由接口的第一个路由地址indexPage,因为你已经登录了,系统不会给你跳到登录页,除非你点击退出登录。

1.2) 这里  to.fullPath == '/'  判断,当登录之后,直接通过ip地址和端口号访问时,跳转到第一个路由页面indexPage。如:http://10.12.7.76:6090/,这样直接访问。

1.3) 这个 to.fullPath == '/'  判断后面的else,是为了处理两个问题

    1.3.1) 如果是点击了一个菜单,然后点击刷新,需要保持在当前的页面。

    1.3.2) 如果在当前页面点击一个按钮,通过打开新窗口跳转路由到另一个页面。如从当前故障报警详情里跳到实时监控页面。(ps:如果不这么做,你跳转去的页面会变成路由默认的第一个页面)。

没有登录,没有token的情况: 

1.4)  

// 没有token

    if (whiteList.indexOf(to.path) !== -1) {

      // 在免登录白名单,直接进入

      next()

若依:如何去掉首页,设置登录后跳转到第一个路由菜单(怎么样去掉)

    } else {

      next(`/login?redirect=${to.fullPath}`) // 否则全部重定向到登录页。

      // 但to.fullPath有可能为%2F,即http://172.16.6.205:9090/login?redirect=%2F,不带任何跳转路由。这时候,请看下文中 login.vue 的跳转方法。

      NProgress.done()

    }

router.beforeEach((to, from, next) => { NProgress.start() if (getToken()) { // 登录之后,访问路由会执行这个方法。 /* has token*/ // 已经登录了,但你想跳到登录页。那系统会跳到路由接口的第一个路由地址,不会给你跳到登录页,除非你点击退出登录。 if (to.path === '/login') { next({ path: '/' }) NProgress.done() } else { if (store.getters.roles.length === 0) { // 判断当前用户是否已拉取完user_info信息 store.dispatch('GetInfo').then(res => { // 拉取user_info const roles = res.roles store.dispatch('GenerateRoutes', { roles }).then(accessRoutes => { // 根据roles权限生成可访问的路由表 // 修改默认首页 // console.log(accessRoutes, from, to.fullPath) router.addRoutes(accessRoutes) // 动态添加可访问路由表 if (to.fullPath == '/') { // 当登录之后,直接通过ip地址和端口号访问时,跳转到第一个路由页面indexPage。如:http://10.12.7.76:6090/,这样直接访问。 let pathIndex = '' pathIndex = accessRoutes[0].path + '/' + accessRoutes[0].children[0].path // replace: true只是一个设置信息,告诉VUE本次操作后,不能通过浏览器后退按钮,返回前一个路由。 next({ path: pathIndex, replace: true }) // hack方法 确保addRoutes已完成 } else { // 如果是点击了一个菜单,然后刷新,保持在当前的页面。 // 如果是从其他页面点击,通过打开新窗口跳转路由。如从当前故障报警详情里跳到实时监控页面。 next({ ...to, replace: true }) // hack方法 确保addRoutes已完成 // 使用next({ ...to, replace: true })来确保addRoutes()时动态添加的路由已经被完全加载上去。 } // 修改默认首页end }) }) .catch(err => { store.dispatch('LogOut').then(() => { Message.error(err) next({ path: '/login' }) }) }) } else { // 跳转到对应的页面 next() } } } else { // 没有token if (whiteList.indexOf(to.path) !== -1) { // 在免登录白名单,直接进入 next() } else { next(`/login?redirect=${to.fullPath}`) // 否则全部重定向到登录页。 // 但to.fullPath有可能为%2F,即http://172.16.6.205:9090/login?redirect=%2F,不带任何跳转路由。这时候,请看login.vue的跳转方法。 NProgress.done() } }})

2) src/store/permission.js 需要修改的地方

3)  src/router/index.js  需要把首页注释

4) src/utils/request.js  需要修改的地方

5) src/system/user/profile/resetPwd.vue 和 src/system/user/profile/userInfo.vue

6) src/layout/components/Topbar.vue

3、针对  login.vue  做出相应的修改。这里也很重要。

this.$store.dispatch('Login', params).then(() => { // 1、跳到登录后指定跳转的页面或者登录后跳到首页 // this.$router.push({ path: this.redirect || '/' }).catch(() => {}) // 2、登录后跳到路由默认的第一个路由页面 this.$store.dispatch('GetInfo').then(res => { // 拉取完user_info信息 const roles = res.roles this.$store.dispatch('GenerateRoutes', { roles }).then(accessRoutes => { // 根据roles权限生成可访问的路由表 // console.log(accessRoutes, from, to.fullPath) this.$router.addRoutes(accessRoutes) // 动态添加可访问路由表 let pathIndex = '' pathIndex = accessRoutes[0].path + '/' + accessRoutes[0].children[0].path // 设置默认首页地址indexPage // console.log(this.redirect, pathIndex) // 1、this.redirect == undefined,主要针对直接从http://172.16.6.205:9090/login,登入系统。 // 2、this.redirect == '/',主要针对直接从这个http://172.16.6.205:9090/login?redirect=%2F,登入系统。因为没有设置重定向的路由 // 如果登录的时候出现1、2两种情况,那么就跳到路由的第一个路由页面,如果登录的时候,有设置可以访问的重定向地址,那么登录后就跳到重定向地址。 if (pathIndex != '') { this.$router.push({ path: this.redirect == '/' || this.redirect == undefined ? pathIndex : this.redirect }).catch(() => {}) // 跳转重定向页面或跳到默认首页indexPage } }) }) .catch(err => { this.$store.dispatch('LogOut').then(() => { Message.error(err) next({ path: '/login' }) }) }) }) .catch(error => { this.errorMsg = error this.loading = false this.getCode() })

3.1)没有token,在登录页面登录,会先执行这个登录方法。

          this.$store.dispatch('Login', params).then(() => {})

3.3.1)访问登录页面,调起获取路由接口获取到路由数据后,然后判断是否有设置重定向的路由地址。

a、this.redirect == undefined,主要针对直接从http://172.16.6.205:9090/login,登入系统。

b、this.redirect == '/',主要针对直接从这个http://172.16.6.205:9090/login?redirect=%2F,登入系统。因为没有设置重定向的路由

如果登录的时候,出现a、b两种情况,那么就跳到路由的第一个路由页面;

如果登录的时候,有设置可以访问的重定向地址,那么登录后就跳到重定向地址。

 if (pathIndex != '') {

      this.$router.push({ path: this.redirect == '/' || this.redirect == undefined ? pathIndex : this.redirect }).catch(() => {}) // 跳转重定向页面或跳到默认首页indexPage

}

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

上一篇:OK源码中国2022年首发宝塔企业破解版本,宝塔企业版最新7.9.4完整破解版本-OK源码中国破解(okhttp源码解读)

下一篇:若依表单中上传文件/图片(表单上传文件)

  • 营销活动,单位让现场观众抽现金奖如何入账?
  • 补发上年度奖金如何计税
  • 财务往来账对账制度
  • 与收益相关的政府补助会计分录总额法
  • 财务合理化建议例子
  • 股权增值转让的财税处理
  • 调整增值税误差的原因
  • 股东拿不到钱
  • 购买方退货的会计处理
  • 非增值税应税项目有哪些2023
  • 营改增后增值税暂行条例实施细则
  • 应交税费未交增值税明细账
  • 从财务报表中可以了解企业的哪些信息?作用是什么?
  • 进项发票已经抵扣怎么做退回处理
  • 外汇收入会计分录
  • 登记为一般纳税人后可以转为小规模纳税人
  • 现金日记账如何结账
  • 出纳人员怎么进入会计
  • 直接计入费用的税
  • 开具的电子发票需要打印出来做账吗
  • win 10动态锁是什么
  • 信息技术费用如何做分录
  • 材料委托加工
  • 摊余成本计量的金融资产若溢价购买小于
  • 在一株植物上行走的作文
  • 坏账准备的借贷方向表示什么意思
  • vue父组件子组件
  • groupdel命令详解
  • 免征增值税怎么入账
  • python安装后找不到了
  • 开公司车出差违章了谁负责
  • 营改增后残保金计入什么科目
  • 增值税发票名称可以写个人吗
  • 当月销售次月开票就按次月申报
  • MySQL中使用什么语句来更新表中的记录
  • SQL Server 2008用'sa'登录失败,启用'sa'登录的解决办法
  • 小规模差额征税是什么意思
  • 饭馆增值税
  • 接受捐赠的增值税可以抵扣吗
  • 货物运输企业的经营内容
  • 销售奖金交税由谁承担
  • 报销无法取得发票
  • 本月购进金额怎么算
  • 印花税的计算公式应纳税所得额包含增值税吗
  • 发票遗失复印件可以入账吗
  • 劳务支出如何做账
  • 废旧物资收购发票政策2018
  • 住房租金专项附加扣除金额
  • 从银行提取现金分录
  • 中小型企业产品定位方案
  • 职工教育经费可以结转几年继续抵扣吗
  • 挂靠收入如何做账处理?
  • 新公司现金日记账怎么记账的
  • 戴尔笔记本电脑开不了机
  • win8怎么打开系统设置
  • 恢复已删除的聊天记录微信
  • win8.1无法连接wifi
  • linux fflush
  • Unity3D游戏开发培训课程大纲
  • 位图字体图片
  • 搭建安卓开发环境必须的工具
  • 安卓手机微信取消窗口化
  • shell数值比较
  • 批处理命令教程
  • [置顶]bilinovel
  • javascript教程chm
  • js动态执行代码
  • python简单gui
  • python django运行
  • 国家税务局通用定额发票查询
  • 公司代扣税怎么办理
  • 深圳企业所得税税率多少
  • 怎么知道税控盘有没有注销
  • 百旺金赋跨月专票作废
  • 国家税务局发票真伪查验平台
  • 税务实名认证如何操作
  • 深圳市百旺信投资有限责任公司
  • 企业需要缴纳哪些费用
  • 2021年小规模纳税人优惠政策
  • 城镇土地使用税税率
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设