前言:以下内容基于React全家桶+AntD实战课程的学习实践过程记录。最终成果github地址:https://github.com/66Web/react-antd-manager,欢迎star。


一、创建角色

  1. RBAC,即基于角色的访问控制(Role-Based Access Control),是优秀的权限控制模型
  2. 主要通过角色和权限建立管理,再赋予用户不同的角色,来实现权限控制的目标

      

  • 角色列表展示:对应Easy Mock数据接口/role/list

    {
    "code": 0,
    "list": {
    "item_list|7": [{
    "id|+1": 1,
    "role_name": /(管理人员)|(客服专员)|(财务专员)|(市场专员)|(人力专员)|(研发)|(测试)|(系统管理员)/,
    "status|0-1": 1,
    "authorize_user_name": "@cname",
    "authorize_time": 1521270166000,
    "create_time": 1499305790000,
    "menus": ["/home", "/ui/buttons", "/ui/modals", "/ui/loadings", "/ui/notification", "/ui/messages", "/ui/tabs", "/ui/gallery", "/ui/carousel", "/ui"]
    }]
    },
    "page": 1,
    "page_size": 10,
    "total_count": 25,
    "page_count": 3
    }
  1. 调用封装好的axios.requestList()获取角色数据

    componentWillMount(){
    this.requestList();
    } requestList = ()=>{
    axios.requestList(this, '/role/list', {})
    }
  2. 使用封装好的ETable组件实现角色列表的展示

    <div className="content-wrap">
    <ETable
    updateSelectedItem={Utils.updateSelectedItem.bind(this)}
    selectedRowKeys={this.state.selectedRowKeys}
    dataSource={this.state.list}
    columns={columns}
    />
    </div>
  • 创建角色:Modal弹框中嵌入表单子组件

  1. 表单组件:RoleForm = Form.create({})(RoleForm)实现表单数据的双向绑定

    // 角色创建
    class RoleForm extends React.Component{ render(){
    const { getFieldDecorator } = this.props.form;
    const formItemLayout = {
    labelCol: {span: 5},
    wrapperCol: {span: 16}
    };
    return (
    <Form layout="horizontal">
    <FormItem label="角色名称" {...formItemLayout}>
    {
    getFieldDecorator('role_name',{
    initialValue:''
    })(
    <Input type="text" placeholder="请输入角色名称"/>
    )
    }
    </FormItem>
    <FormItem label="状态" {...formItemLayout}>
    {
    getFieldDecorator('state',{
    initialValue:1
    })(
    <Select>
    <Option value={1}>开启</Option>
    <Option value={0}>关闭</Option>
    </Select>
    )}
    </FormItem>
    </Form>
    );
    }
    }
    RoleForm = Form.create({})(RoleForm);
  2. Modal弹框中应用表单组件:通过wrappedComponentRef={(inst) => this.roleForm = inst }获取表单元素的数据对象

    <Modal
    title="创建角色"
    visible={this.state.isRoleVisible}
    onOk={this.handleRoleSubmit}
    onCancel={()=>{
    this.roleForm.props.form.resetFields();//表单重置
    this.setState({
    isRoleVisible:false
    })
    }}
    >
    <RoleForm wrappedComponentRef={(inst) => this.roleForm = inst }/>
    </Modal>
  3. 点击【创建角色】按钮弹出弹框:给onClick事件绑定this.handleRole(),设置this.state.isRoleVisible为true

  4. 点击【OK】提交创建角色:给onOk事件绑定this.handleRoleSubmit()。①通过this.roleForm.props.form.getFieldsValue()获取表单的值,赋给params;②接口访问成功后,关闭弹框,刷新列表数据。

    // 角色提交
    handleRoleSubmit = ()=>{
    let data = this.roleForm.props.form.getFieldsValue(); //获取表单的值
    axios.ajax({
    url:'role/create', //Easy Mock中只有{"code": 0}
    data:{
    params:{
    ...data
    }
    }
    }).then((res)=>{
    if(res.code === 0){
    this.setState({
    isRoleVisible:false //关闭弹框
    })
    this.requestList(); //刷新列表数据
    }
    })
    }

      

二、设置权限

  • 设置权限表单组件 :AntD Tree树形结构组件的使用
  1. TreeNode树形节点:const TreeNode = Tree.TreeNode;
  2. 加载完整的权限列表:本地定义menuConfig.js权限列表文件,通过递归方法渲染TreeNode
    import menuConfig from '../../config/menuConfig'
    
    renderTreeNodes = (data,key='') => {
    return data.map((item) => {
    let parentKey = key+item.key;
    if (item.children) {
    return (
    <TreeNode title={item.title} key={parentKey} dataRef={item} className="op-role-tree">
    {this.renderTreeNodes(item.children,parentKey)}
    </TreeNode>
    );
    } else if (item.btnList) {
    return (
    <TreeNode title={item.title} key={parentKey} dataRef={item} className="op-role-tree">
    { this.renderBtnTreedNode(item,parentKey) }
    </TreeNode>
    );
    }
    return <TreeNode {...item} />;
    });
    }; renderBtnTreedNode = (menu,parentKey='')=> {
    const btnTreeNode = []
    menu.btnList.forEach((item)=> {
    // console.log(parentKey+'-btn-'+item.key);
    btnTreeNode.push(<TreeNode title={item.title} key={parentKey+'-btn-'+item.key} className="op-role-tree"/>);
    })
    return btnTreeNode;
    } <Tree
    checkable
    defaultExpandAll
    >
    <TreeNode title="平台权限" key="platform_all">
    {this.renderTreeNodes(menuConfig)}
    </TreeNode>
    </Tree>      
  • Modal弹框中应用表单组件:
  • 点击【设置权限】按钮弹出弹框:判断若没有this.state.selectedItem,提示需“选择”

    //权限设置
    handlePermission = ()=>{
    if (!this.state.selectedItem) {
    Modal.info({
    title: '信息',
    content: '请选择一个角色'
    })
    return;
    }
    this.setState({
    isPermVisible: true,
    detailInfo: this.state.selectedItem //角色详细信息
    });
    let menuList = this.state.selectedItem.menus; //角色权限
    this.setState({
    menuInfo:menuList
    })
    }  
  • 点击【OK】提交权限:给onOk事件绑定this.handlePermEditSubmit()

三、菜单调整

四、用户授权


注:项目来自慕课网

【共享单车】—— React后台管理系统开发手记:权限设置和菜单调整(未完)的更多相关文章

  1. 【共享单车】—— React后台管理系统开发手记:主页面架构设计

    前言:以下内容基于React全家桶+AntD实战课程的学习实践过程记录.最终成果github地址:https://github.com/66Web/react-antd-manager,欢迎star. ...

  2. 【共享单车】—— React后台管理系统开发手记:Redux集成开发

    前言:以下内容基于React全家桶+AntD实战课程的学习实践过程记录.最终成果github地址:https://github.com/66Web/react-antd-manager,欢迎star. ...

  3. 【共享单车】—— React后台管理系统开发手记:项目工程化开发

    前言:以下内容基于React全家桶+AntD实战课程的学习实践过程记录.最终成果github地址:https://github.com/66Web/react-antd-manager,欢迎star. ...

  4. 【共享单车】—— React后台管理系统开发手记:城市管理和订单管理

    前言:以下内容基于React全家桶+AntD实战课程的学习实践过程记录.最终成果github地址:https://github.com/66Web/react-antd-manager,欢迎star. ...

  5. 【共享单车】—— React后台管理系统开发手记:AntD Form基础组件

    前言:以下内容基于React全家桶+AntD实战课程的学习实践过程记录.最终成果github地址:https://github.com/66Web/react-antd-manager,欢迎star. ...

  6. 【共享单车】—— React后台管理系统开发手记:Router 4.0路由实战演练

    前言:以下内容基于React全家桶+AntD实战课程的学习实践过程记录.最终成果github地址:https://github.com/66Web/react-antd-manager,欢迎star. ...

  7. 【共享单车】—— React后台管理系统开发手记:员工管理之增删改查

    前言:以下内容基于React全家桶+AntD实战课程的学习实践过程记录.最终成果github地址:https://github.com/66Web/react-antd-manager,欢迎star. ...

  8. 【共享单车】—— React后台管理系统开发手记:AntD Table高级表格

    前言:以下内容基于React全家桶+AntD实战课程的学习实践过程记录.最终成果github地址:https://github.com/66Web/react-antd-manager,欢迎star. ...

  9. 【共享单车】—— React后台管理系统开发手记:AntD Table基础表格

    前言:以下内容基于React全家桶+AntD实战课程的学习实践过程记录.最终成果github地址:https://github.com/66Web/react-antd-manager,欢迎star. ...

随机推荐

  1. (翻译)FakeKaKao木马分析

    这是暑假时看到的一篇病毒分析文章,觉得里面有很多东西值得学习,刚好这几天有空就将它翻译了出来.有不对的地方请大家指正! FakeKaKao木马分析 Virus Bulletin是一个关于流氓软件与垃圾 ...

  2. Ajax基础知识 浅析(含php基础语法知识)

    1.php基础语法    后缀名为.php的文件 (1) echo   向页面中输入字符串  <?php    所有php相关代码都要写在<?php ?>这个标签之中 echo &q ...

  3. php实现二维码

    封装函数 function verifyImage($len=3){ //session_start(); $scr="abcdefghijklmnoqprstuvwxyzABCDEFJHI ...

  4. C# 编写的Windows serice程序. 安装时出现异常!

    初学Windows Service 程序的编写,按照MSDN上写了一个service! 遇到安装服务的错误, 能帮忙看下是什么原因吗? 下面是在命令行下的安装结果: 正在运行事务处理安装. 正在开始安 ...

  5. 插件 原生js 省市区 三级联动 源码

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  6. Linux下Nginx使用

    1. 安装 CentOS 7上Nginx的安装和启动方法如下 # yum install nginx # firewall-cmd --permanent --zone=public --add-se ...

  7. Linux内核情景分析之异常访问,用户堆栈的扩展

    情景假设: 在堆内存中申请了一块内存,然后释放掉该内存,然后再去访问这块内存.也就是所说的野指针访问. 当cpu产生页面错误时,会把失败的线性地址放在cr2寄存器.线性地址缺页异常的4种情况 1.如果 ...

  8. msvc/gcc:中用#pragma指令关闭特定警告(warning)

    在使用一些第三方库或源码的时候,经常会遇到编译时产生warnings情况,这些warning不是我们自己的代码产生的,当然也不好去修改,但每次编译都显示一大堆与自己代码无关的警告也着实看着不爽,更麻烦 ...

  9. 【linux高级程序设计】(第十二章)Linux多线程编程

    线程与进程对比 1.用户空间对比 2.内核空间资源对比 在创建线程时,Linux内核仍然创建一个新的PCB来标识这个线程.内核并不认为进程与线程有差别. 进程是操作系统管理资源的基本单元,线程时Lin ...

  10. python接口自动化4-绕过验证码登录(cookie)【转载】

    本篇转自博客:上海-悠悠 原文地址:http://www.cnblogs.com/yoyoketang/tag/python%E6%8E%A5%E5%8F%A3%E8%87%AA%E5%8A%A8%E ...