• 技术文章 >web前端 >js教程

    基于Vue自定义指令实现按钮级权限控制的方法

    不言不言2018-07-04 11:03:59原创1009
    这篇文章主要介绍了基于vue自定义指令实现按钮级权限控制,本文给大家介绍的非常详细,感兴趣的朋友一起学习吧

    思路:

    按钮权限也可以用v-if判断,但是如果页面过多,每个页面页面都要获取用户权限role和路由表里的meta.btnPermissions,然后再做判断,感觉有点麻烦,而自定义指令,只需在权限按钮加入该指令即可。

    废话不多说,上代码...

    路由配置:

    path: '/permission',
      component: Layout,
      name: '权限测试',
      meta: { btnPermissions: ['admin','supper','normal'] }, //页面需要的权限
      children: [
       {
        path: 'supper',
        component: _import('system/supper'),
        name: '权限测试页',
        meta: { btnPermissions: ['admin','supper'] } //页面需要的权限
       },
       {
        path: 'normal',
        component: _import('system/normal'),
        name: '权限测试页',
        meta: { btnPermissions: ['admin'] } //页面需要的权限
       }
      ]

    自定义指令:

    import Vue from 'vue'
    /**权限指令**/
    const has = Vue.directive('has', {
     bind: function (el, binding, vnode) {
      // 获取按钮权限
      let btnPermissions = vnode.context.$route.meta.btnPermissions.split(",");
      if (!Vue.prototype.$_has(btnPermissions)) {
       el.parentNode.removeChild(el);
      }
     }
    });
    // 权限检查方法
    Vue.prototype.$_has = function (value) {
     let isExist = false;
     let btnPermissionsStr = sessionStorage.getItem("btnPermissions");
     if (btnPermissionsStr == undefined || btnPermissionsStr == null) {
      return false;
     }
     if (value.indexOf(btnPermissionsStr) > -1) {
      isExist = true;
     }
     return isExist;
    };
    export {has}

    然后在main.js文件引入文件

    import has from './public/js/btnPermissions.js';

    页面中按钮只需加v-has即可

    <el-button @click='editClick' type="primary" v-has>编辑</el-button>

    结语:

    权限这种事需要前后端结合,前端尽可能的去控制,记住:永远不相信用户输入!

    以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

    相关推荐:

    Vue使用Redux的方法

    Vue+mui实现图片的本地缓存

    vue路由拦截及页面跳转设置的方法介绍

    以上就是基于Vue自定义指令实现按钮级权限控制的方法的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    上一篇:Vue使用Redux的方法 下一篇:vue-cli项目根据线上环境分别打出测试包和生产包的方法
    PHP编程就业班

    相关文章推荐

    • 你能搞懂JS的this指向问题吗?看看这篇文章• 浅析react18中的新概念Transition• javascript跨域的原因是什么• 什么是事件循环?详解Node.js中的事件循环• 一起来分析JavaScript五大事件

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网