电商后台管理系统——权限管理模块

电商后台管理系统——权限管理模块电商后台管理系统——权限管理模块电商后台管理系统的权限管理模块分为角色列表和权限列表两部分,两部分流程图大概如下权限列表实现过程:

大家好,又见面了,我是你们的朋友全栈君。

电商后台管理系统——权限管理模块

电商后台管理系统的权限管理模块分为角色列表和权限列表两部分,两部分流程图大概如下
在这里插入图片描述
在这里插入图片描述

1.权限列表实现过程

创建路由组件配置路由——布局基本面包屑导航卡片视图——表单绑定数据提供方法获取权限列表数据
表单有三列数据:权限名称, 路径 ,权限等级,权限等级通过作用域与 插槽放入el-tag实现自定义格式,再根据数据的level判断显示哪个等级的tag
表单结构:

<el-card>
      <el-table :data="rightList" border stripe>
          <el-table-column type="index"></el-table-column>
          <el-table-column label="权限名称" prop="authName"></el-table-column>
          <el-table-column label="路径" prop="path"></el-table-column>
          <el-table-column label="权限等级" prop="level">
            <template slot-scope="scope">
             <el-tag v-if="scope.row.level==='0'">一级</el-tag>
             <el-tag type="success" v-else-if="scope.row.level==='1'">二级</el-tag>
             <el-tag type="warning" v-else>三级</el-tag>
             </template>
          </el-table-column>
      </el-table>
  </el-card>

方法:通过发送get请求获取数据

methods:{ 
   
        //获取权限列表
      async  getRightList(){ 
   
            const { 
   data:res}=await this.$http.get('rights/list')
            if(res.meta.status!==200){ 
   
                return this.$message.error('获取权限列表失败')
            }
            this.rightList=res.data
        }
    }

2.角色列表实现过程

整个页面功能有添加角色功能,以及一个表单,表单有三列数据:角色名称,角色描述,操作 。操作通过作用域插槽实现布局编辑,删除,分配权限按钮。
实现流程:添加角色列表组件配置路由——布局基本面包屑导航卡片视图表单等——表单绑定数据提供方法获取权限列表数据——操作功能模块实现
困难点:

1.表单的展开列实现还需要通过三重嵌套for循环生成下拉列表
通过在作用域与插槽里使用栅格布局el-row(行),el-col(列),分为24列
通过scope.row.children拿到一级权限数据,将key值设置为拿到的数据item的id

<el-tag closable @close="removeRightById(scope.row, item1.id)">{ 
   { 
   item1.authName}}</el-tag>

通过 for 循环 嵌套渲染二级权限

`<el-row :class="[i2 === 0 ? '' : 'bdtop', 'vcenter']" v-for="(item2, i2) in item1.children" :key="item2.id">`

i2是索引
通过for继续渲染三级权限

 <el-tag type="warning" v-for="(item3, i3) in item2.children" :key="item3.id" closable @close="removeRightById(scope.row, item3.id)">{ 
   { 
   item3.authName}}</el-tag>

2.分配权限的操作

分配权限按钮对话框(树形结构弹窗)——分配权限按钮绑定点击事件——渲染所有权限数据一级默认选中数据到页面树形结构——分配权限对话框确定按钮绑定分配权限事件

<el-tree :data="rightslist" :props="treeProps" show-checkbox node-key="id" default-expand-all :default-checked-keys="defKeys" ref="treeRef"></el-tree>

所有权限数据获取与前面数据获取写法一致。默认数据选中需要通过 el-tree的属性: default-checked-keys=“defKeys” defkeys 。
思路是点击分配权限按钮时将当前角色所有的三级权限id存入defkeys,当前角色的id通过在点击分配权限按钮事件里传入scope.row

getLeafKeys(node, arr) { 
   
      // 如果当前 node 节点不包含 children 属性,则是三级节点
      if (!node.children) { 
   
        return arr.push(node.id)
      }

      node.children.forEach(item => this.getLeafKeys(item, arr))
    },

上面代码块是通过递归的形式,获取角色下所有三级权限的id,并保存到 defKeys 数组中(判断是否包含child属性,包含则不是三级节点,则让该节点的子节点循环遍历递归调用该函数)
注意需要监听关闭对话框事件,因为需要重置defkeys数组,不清空的话,每次之前的角色都保存在数组里了。
确定按钮绑定事件:
el-tree的getCheckedKeys(),getHalfCheckedKeys()可以获得全选和半选中的数组,将数据post传入后台,再重新调用获取角色方法。

async allotRights() { 
   
      const keys = [
        ...this.$refs.treeRef.getCheckedKeys(),
        ...this.$refs.treeRef.getHalfCheckedKeys()
      ]

      const idStr = keys.join(',')

      const { 
    data: res } = await this.$http.post(
        `roles/${ 
     this.roleId}/rights`,
        { 
    rids: idStr }
      )

      if (res.meta.status !== 200) { 
   
        return this.$message.error('分配权限失败!')
      }

      this.$message.success('分配权限成功!')
      this.getRolesList()
      this.setRightDialogVisible = false
    }
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/145903.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • selenium 和 IP代理池

    selenium 和 IP代理池3.1seleniumselenium:Selenium是一个自动化测试工具,利用它可以驱动浏览器执行特定的动作,如点击、下拉等操作(模拟浏览器操作)同时还可以获取浏览器当前呈现的页面的源代码,做到可见即可爬Selenium支持非常多的浏览器,如Chrome、Firefox、PhantomJS等浏览器对象的初始化并将其赋值为browser对象。接下来,我们要做的就是调用…

    2022年5月2日
    119
  • java h2数据库_JAVA 项目中使用 H2 数据库

    java h2数据库_JAVA 项目中使用 H2 数据库JAVA项目中使用H2数据库发布时间:2018-06-0815:43,浏览次数:823,标签:JAVA为什么要使用H2数据库H2数据库是可以嵌入到JAVA项目中的,因为只需要导入一个jar包即可,所以非常的方便。项目中导入H2将H2的jar包放到classpath里即可,我是用的maven,maven的配置如下com.h2databaseh2<version>1.4.1…

    2022年8月31日
    3
  • r语言的for循环_两效十MVR强制循环

    r语言的for循环_两效十MVR强制循环R语言for循环for循环本教程将针对初学者,探讨如何在R语言中编写基本的for循环和嵌套式for循环。简单for循环R中for循环的基本语法是:for(iR简单for循环示例:#forloopinR上述例子中直接将结果进行print,在实际应用中基本不会这么做。一般会将输出结果以向量或其他形式储存。如下:x5)for(iin1:5){x[i]2}x#outp…

    2025年7月14日
    3
  • 锂电池3V升12V(AH6901)低成本替代6291升压芯片

    锂电池3V升12V(AH6901)低成本替代6291升压芯片锂电池3V升12V(AH6901)低成本替代6291升压芯片应用于数码相机,移动电源,蓝牙音箱,插卡音箱、LED台灯便捷DVD,MID,移动电话等数码产品AH6901是一款小封装(SOT23-6)、CC(恒流)模式的PWM升压IC,适用于锂电池(3~4.2V)输出5V,1A的移动电源应用。AH6901输入电压范围可由最低2.6伏特到最高6伏特,输出电压3.3–20V可调整且内部MOS输出开关电流可高达2A,封装为SOT23-6,工作频率为1MHZ,可以搭配3.3uh小型贴片电感,减少成品体积,非常适

    2022年10月6日
    5
  • webstorm激活教程破解方法

    webstorm激活教程破解方法,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月15日
    66
  • java db4o,DB4O–java对象数据库[通俗易懂]

    java db4o,DB4O–java对象数据库[通俗易懂]特点直接存储java对象,抛弃对象映射的繁琐可以使用简单的查询语句致命缺点与java语言绑定demogitee地址https://gitee.com/ichiva/db4o-demo.git主要依赖org.fudaa.com.db4odb4o-java55.5.1编写测试用例官方实体类@DatapublicclassCar{privateIntegerid;privateString…

    2022年7月21日
    13

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号