Blame view
src/views/permission/directive.vue
3.16 KB
d7d9c38c2 auto commit the c... |
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 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 |
<template> <div class="app-container"> <switch-roles @change="handleRolesChange" /> <div :key="key" style="margin-top:30px;"> <div> <span v-permission="['admin']" class="permission-alert"> Only <el-tag class="permission-tag" size="small">admin</el-tag> can see this </span> <el-tag v-permission="['admin']" class="permission-sourceCode" type="info"> v-permission="['admin']" </el-tag> </div> <div> <span v-permission="['editor']" class="permission-alert"> Only <el-tag class="permission-tag" size="small">editor</el-tag> can see this </span> <el-tag v-permission="['editor']" class="permission-sourceCode" type="info"> v-permission="['editor']" </el-tag> </div> <div> <span v-permission="['admin','editor']" class="permission-alert"> Both <el-tag class="permission-tag" size="small">admin</el-tag> and <el-tag class="permission-tag" size="small">editor</el-tag> can see this </span> <el-tag v-permission="['admin','editor']" class="permission-sourceCode" type="info"> v-permission="['admin','editor']" </el-tag> </div> </div> <div :key="'checkPermission'+key" style="margin-top:60px;"> <aside> {{ $t('permission.tips') }} <br> e.g. </aside> <el-tabs type="border-card" style="width:550px;"> <el-tab-pane v-if="checkPermission(['admin'])" label="Admin"> Admin can see this <el-tag class="permission-sourceCode" type="info"> v-if="checkPermission(['admin'])" </el-tag> </el-tab-pane> <el-tab-pane v-if="checkPermission(['editor'])" label="Editor"> Editor can see this <el-tag class="permission-sourceCode" type="info"> v-if="checkPermission(['editor'])" </el-tag> </el-tab-pane> <el-tab-pane v-if="checkPermission(['admin','editor'])" label="Admin-OR-Editor"> Both admin or editor can see this <el-tag class="permission-sourceCode" type="info"> v-if="checkPermission(['admin','editor'])" </el-tag> </el-tab-pane> </el-tabs> </div> </div> </template> <script> import permission from '@/directive/permission/index.js' // 权限判断指令 import checkPermission from '@/utils/permission' // 权限判断函数 import SwitchRoles from './components/SwitchRoles' export default { name: 'DirectivePermission', components: { SwitchRoles }, directives: { permission }, data() { return { key: 1 // 为了能每次切换权限的时候重新初始化指令 } }, methods: { checkPermission, handleRolesChange() { this.key++ } } } </script> <style lang="scss" scoped> .app-container { /deep/ .permission-alert { width: 320px; margin-top: 15px; background-color: #f0f9eb; color: #67c23a; padding: 8px 16px; border-radius: 4px; display: inline-block; } /deep/ .permission-sourceCode { margin-left: 15px; } /deep/ .permission-tag { background-color: #ecf5ff; } } </style> |