当前位置:   article > 正文

Vue 前端页面按钮权限控制_hasperm

hasperm

前言

按钮权限控制的功能其实在前面的一篇的页面权限管理也包含有这个功能,但是没有凸显出来,所以现在单独写一篇文章用来记录一下


一、什么是按钮权限控制?

刚刚做完了一个后台管理系统,有用到按钮权限控制,所以记录一下。按钮权限控制就是说对于不同的用户,可操作的按钮是不一样的,比如有些按钮有些用户是看不见,有些用户是可以看得见的。应用场景:用户A能看得到‘新增’按钮,而用户B是看不到‘新增’按钮的

二、使用步骤

按钮权限控制,我知道的有两种解决方案:1.定义一个全局方法,配合v-if实现(下面会介绍);2.使用自定义指令;
思路:在用户登录成功后,获取用户的按钮权限(数组格式),存储到store中,然后在工具类中定义一个公共函数hasPermission,在按钮中调用hasPermission()函数,把传入的关键字和store的按钮权限进行对比,看看是否存在,如果存在就显示,不存在就隐藏

1.获取按钮权限数据,存储在store中

用户登录成功之后就会调用getInfo方法获取用户页面权限和按钮权限
在这里插入图片描述
permissionList即为按钮权限的数组格式
在这里插入图片描述
store文件中的user.js定义getInfo

import {
    login,
    logout,
    getInfo
} from '@/api/user'
import cookieUtils from '../../utils/auth'
// eslint-disable-next-line no-unused-vars
import router from '../../router/index'
// eslint-disable-next-line no-unused-vars
import store from '../../store'

import wutong from '@/assets/img/wutong_img.png'
const getDefaultState = () => {
    return {
        nickname: '',
        userId: '',
        // avatar: 'https://www.gravatar.com/avatar/6560ed55e62396e40b34aac1e5041028',
        avatar: wutong,
        roleName: '',
        menus: [],
        permissions: []
    }
}

const state = getDefaultState()

const mutations = {
    SET_USER: (state, userInfo) => {
        state.nickname = userInfo.nickname
        state.userId = userInfo.userId
        state.roleName = userInfo.roleName
        state.menus = userInfo.menuList
        state.permissions = userInfo.permissionList
    },
    RESET_USER: (state) => {
        state.nickname = ''
        state.userId = ''
        state.roleName = ''
        state.menus = []
        state.permissions = []
    }

}

const actions = {

    // get user info
    GetInfo({
        commit,
        state
    }) {
        return new Promise((resolve, reject) => {
            getInfo().then(data => {
                // console.log('get User Info: ', data)
                // 账号在其他地方登录
                if (!data) {
                    commit('RESET_USER')
                    window.sessionStorage.removeItem('overdueloan')
                    // must remove  token  first
                    cookieUtils.removeJwtToken()
                    cookieUtils.removeUserType()
                    router.push({ path: '/login' })
                    return
                }

                // 储存用户信息
                commit('SET_USER', data.data.userPermission)
                // cookie保存登录状态,仅靠vuex保存的话,页面刷新就会丢失登录状态
                // 生成路由
                const userPermission = data.data.userPermission
                store.dispatch('GenerateUserRoutes', userPermission).then(() => {
                    // 生成该用户的新路由json操作完毕之后,调用vue-router的动态新增路由方法,将新路由添加
                    router.addRoutes(store.getters.addRouters)
                })
                resolve(data)
            })
            // .catch(error => {
            //   reject(error)
            // })
        })
    },


}
export default {
    namespaced: true,
    state,
    mutations,
    actions
}

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91

导出getters方便使用
在这里插入图片描述

2.定义公共函数

在这里插入图片描述
然后全局注册
在这里插入图片描述

3.使用hasPerm控制按钮

在这里插入图片描述
在这里插入图片描述

三.最后一种按钮控制的解决方案是使用自定义指令

因为我没有使用过自定义指令来控制按钮所以我就不在这里介绍了,下面是我在网上看到的自定义指令的写法,可以借鉴借鉴别人的写法,当然你要是有好的写法也欢迎留言介绍

大佬的写法1:自定义指令控制按钮权限

大佬的写法2:自定义指令控制按钮权限

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Li_阴宅/article/detail/774109
推荐阅读
相关标签
  

闽ICP备14008679号