vue自定义权限标签

vue自定义权限标签

技术栈

  • vuex
  • vue自定义标签

开门见山

  1. 创建directive

在这里插入图片描述

  • hasPermi.js

     /**
     * v-hasPermi 操作权限处理
     */
    
    import store from '@/store'
    
    export default {
      inserted(el, binding, vnode) {
        const { value } = binding
        const all_permission = "*:*:*";
        const permissions = store.getters && store.getters.permissions
    
        if (value && value instanceof Array && value.length > 0) {
          const permissionFlag = value
    
          const hasPermissions = permissions.some(permission => {
            return all_permission === permission || permissionFlag.includes(permission)
          })
    
          if (!hasPermissions) {
            el.parentNode && el.parentNode.removeChild(el)
          }
        } else {
          throw new Error(`请设置操作权限标签值`)
        }
      }
    }
    
    
  • index.js

    import hasPermi from './permission/hasPermi'
    
    const install = function(Vue) {
      Vue.directive('hasPermi', hasPermi)
    }
    
    if (window.Vue) {
      window['hasPermi'] = hasPermi
      Vue.use(install); // eslint-disable-line
    }
    
    export default install
    
    
  1. store

在这里插入图片描述

  • user.js

    import {getPermissions} from "@/api/token/assets";
    import async from "async";
    
    const user = {
        state: {
            permissions: []
        },
    
        mutations: {
            SET_PERMISSIONS: (state, permissions) => {
                state.permissions = permissions
            }
        },
    
        actions: {
            // 获取用户信息
            GetInfo({commit}, query) {
                return new Promise((resolve, reject) => {
                    // 获取权限信息(请求后台数据接口)
                    getPermissions(query).then(res => {
                        if ( res.code == 200 ) {
                            commit('SET_PERMISSIONS', res.data)
                        }
                        resolve(res)
                    }).catch(error => {
                        reject(error)
                    })
                })
            }
        }
    }
    
    export default user
    
    
  • getters.js

    const getters = {
      token: state => state.user.token,
      permissions: state => state.user.permissions
    }
    export default getters
    
    
  • index.js

    import Vue from 'vue'
    import Vuex from 'vuex'
    
    import user from './modules/user'
    
    import getters from './getters'
    
    Vue.use(Vuex)
    
    const store = new Vuex.Store({
      modules: {
        user
      },
      getters
    })
    
    export default store
    
    
  1. src目录下创建permission.js

    import router from './router'
    import store from './store'
    import { Message } from 'element-ui'
    
    router.beforeEach((to, from, next) => {
      // to.query 获取url路由请求参数,传递给后端使用
      store.dispatch('GetInfo',to.query).then(() => {
        next()
      }).catch(err => {
        Message.error(err)
      })
    })
    
    
  2. src下的main.js使用

    import Vue from 'vue'
    import App from './App.vue'
    import router from './router'
    import ElementUI from 'element-ui';
    import 'element-ui/lib/theme-chalk/index.css';
    import directive from './directive' // directive
    import store from './store'
    import './permission' // permission control
    
    Vue.use(ElementUI)
    Vue.use(directive)
    
    
    new Vue({
      router,
      store,
      render: h => h(App)
    }).$mount('#app')
    
  3. 按钮标签

     <el-button
                  size="mini"
                  type="text"
                  icon="el-icon-delete"
                  @click="handleDelete(scope.row)"
                  v-hasPermi="['btn:delete']"
              >删除
              </el-button>
    

    说明:

    如果后台接口返回的按钮权限数据里包含btn:delete则删除按钮显示,否则不显示

    后台返回数据如下:

    [
      "btn:list", 
      "btn:add", 
      "btn:delete", 
      "btn:edit"
    ]
    
  • 7
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在给定的引用中,提到了一个自定义指令的权限鉴定功能。根据引用的描述,这个自定义指令似乎可以根据权限列表来判断标签是否具有权限。当标签传递的值在权限列表中存在时,标签被视为有权限。否则,会给标签添加特殊类名 'noRight'。 这个自定义指令可以在判断标签权限时,根据是否含有 'noBtnRight' 类名来进行操作。如果标签含有 'noBtnRight' 类名,则表示没有权限。相反,如果没有 'noBtnRight' 类名,则表示有权限。 在代码示例中,给出了一个事件函数 goToActDetail(e, item),在这个函数中,通过检查点击的元素是否含有 'noBtnRight' 类名来判断是否有权限。如果没有权限,则可以执行相应的操作。如果有权限,则可以执行其他的操作。 总结来说,这个自定义指令是用来进行权限鉴定的,可以通过添加特殊类名来判断标签是否具有权限,并在相应的事件函数中进行权限的处理。<span class="em">1</span><span class="em">2</span> #### 引用[.reference_title] - *1* [vue 自定义指令控制按钮权限](https://blog.csdn.net/weixin_42154189/article/details/129322880)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [vue自定义指令实现按钮权限鉴定](https://blog.csdn.net/weixin_49274461/article/details/127513651)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值