vue后台管理知识点、难点总结04(权限管理)

vue后台管理知识点、难点总结04--权限管理

    • 1 权限管理:
    • 2 菜单权限分析
    • 3 按钮权限分析

1 权限管理:

用户管理,角色管理,菜单管理,角色授权,

用户管理:

vue后台管理知识点、难点总结04(权限管理)_第1张图片

角色管理:

vue后台管理知识点、难点总结04(权限管理)_第2张图片

角色授权:

vue后台管理知识点、难点总结04(权限管理)_第3张图片

菜单管理:

vue后台管理知识点、难点总结04(权限管理)_第4张图片 设置路由:router->index
  //权限管理
  {
    name: 'Acl',
    path: '/acl',
    component: Layout,
    redirect: '/acl/user/list',
    meta: {
      title: '权限管理',
      icon: 'el-icon-lock'
    },
    children: [
      {
        name: 'User',
        path: 'user/list',
        component: () => import('@/views/acl/user/list'),
        meta: {
          title: '用户管理',
        },
      },
      {
        name: 'Role',
        path: 'role/list',
        component: () => import('@/views/acl/role/list'),
        meta: {
          title: '角色管理',
        },
      },
      {
        name: 'RoleAuth',
        path: 'role/auth/:id',
        component: () => import('@/views/acl/role/roleAuth'),
        meta: {
          activeMenu: '/acl/role/list',
          title: '角色授权',
        },
        hidden: true,
      },
      {
        name: 'Permission',
        path: 'permission/list',
        component: () => import('@/views/acl/permission/list'),
        meta: {
          title: '菜单管理',
        },
      },
    ]
  },

写相应的请求路由:api->acl,再倒入到api->index中

import * as trademark from './product/tradeMark' 
import * as attr from './product/attr' 
import * as spu from './product/spu' 
import * as sku from './product/sku' 


//引入权限相关的接口文件
import * as user from './acl/user' //分开export
import role  from './acl/role'  //export default {}
import permission from './acl/permission'

//对外暴露
export default{
    trademark,
    attr,
    spu,
    sku,
    user,
    role,
    permission,
}

在相应的组件内写静态页面和js
注意:发请求一般是在mounted中,也可以在created内

注意: 登录@click事件

<el-button :loading="loading" type="primary" style="width:100%;margin-bottom:30px;" @click.native.prevent="handleLogin">登录</el-button>

2 菜单权限分析

vue后台管理知识点、难点总结04(权限管理)_第5张图片

3 按钮权限分析

vue后台管理知识点、难点总结04(权限管理)_第6张图片

<template>
  <div>
      <el-button type="primary" v-show="$store.state.user.buttons.indexOf('btn.Add1')!=-1">添加按钮1</el-button>
      <el-button type="primary" v-show="$store.state.user.buttons.indexOf('btn.Add2')!=-1">添加按钮2</el-button>
  </div>
</template>

你可能感兴趣的:(vue.js,javascript,前端)