Vue前端项目-首页-获取角色

目录

Vue端代码

1、前端守卫设置

2、Vuex中定义getter

3、新建 getters.js 文件

4、定义 GetInfo 方法获取用户角色信息

5、获取用户信息API

6、请求拦截器

SpringBoot 端

1、Controller层

2、Service 层

3、Mapper接口

4、映射描述文件


描述:

当我们登陆完成后,进去到首页, 在重定向到首页之前需要检查一下vuex 中是否获取了角色信息?

如果vuex的store中还没有 角色信息,需要发送异步请求获取角色信息

Vue端代码

1、前端守卫设置

  • 引入 store 
  • 在未获取角色时, 发起异步请求
import store from '@/store'

// 挂载前端路由导航
router.beforeEach((to, from, next) => {
  if (getToken()) {
    if (to.path === '/login') {
      next({ path: '/' })
    } else {
      if (store.getters.roles.length === 0) {
        // 判断当前用户是否已拉取完user_info信息
        store.dispatch('GetInfo').then(res => {
          // 拉取user_info
          const roles = res.roles
          console.log(roles)
        }).catch(err => {
          console.log(err)
        })
      }
      next()
    }
  } else {
    // 没有 token
    if (whiteList.indexOf(to.path) !== -1) {
      // 在免登陆白名单, 直接进入
      next()
    }
    next(`/login?redirect=${to.path}`)
  }
})

2、Vuex中定义getter

src / store / index.js 中,定义并引入 getter

import Vue from 'vue'
import Vuex from 'vuex'
import user from './modules/user'
import getters from './getters'
Vue.use(Vuex)

export default new Vuex.Store({
  state: {
  },
  mutations: {
  },
  actions: {
  },
  modules: {
    user
  },
  getters
})

3、新建 getters.js 文件

新建 src / store / getters.js 文件, 文件定义getter 方法,并向外暴露 getters对象

const getters = {
  roles: state => state.user.roles
}
export default getters

4、定义 GetInfo 方法获取用户角色信息

在步骤1中,我们调用了store.dispatch('GetInfo') 方法,但还没有定义,现再来定义已经这个方法

在 src / store / modules / user.js 中的 actions 里定义 GetInfo(获取用户角色方法)

// 1.导入 getInfo 获取角色API
import { login, getInfo } from '@/api/login'  

// 2. set方法    
mutations: {
    SET_TOKEN: (state, token) => {
      state.token = token
    
  • 0
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
vue-element-admin是基于Vue.js的后台管理系统模板,该模板使用了Element UI组件库,并提供了丰富的功能和组件。下面是关于vue-element-admin的脑图: vue-element-admin脑图的主要内容包括: 1. 项目结构:脑图展示了vue-element-admin的文件目录结构,包括主要的文件和文件夹,例如src文件夹、components文件夹、views文件夹等。 2. 主要组件:脑图展示了vue-element-admin中的主要组件,包括菜单组件、布局组件、表格组件、表单组件等。每个组件都有详细的说明和用法,方便开发者使用和定制。 3. 功能模块:脑图展示了vue-element-admin中的主要功能模块,包括权限管理、用户管理、角色管理、日志管理等。每个模块都有详细的介绍和功能描述,便于开发者根据实际需求进行定制和扩展。 4. 数据交互:脑图展示了vue-element-admin中的数据交互方式,包括前端请求方式、后端数据接口的定义和使用,以及数据的获取、修改和删除等操作。 5. 扩展和定制:脑图展示了vue-element-admin的扩展和定制方式,包括如何增加新的组件、模块和页面,以及如何修改现有的组件和功能。 通过这个脑图,开发者可以更好地了解vue-element-admin的整体结构和功能,加快学习和开发的速度。同时,脑图也提供了方便的导航和查询功能,方便开发者查找和理解具体的组件和功能模块。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值