复杂的权限按钮控制优化

栏目: IOS · Android · 发布时间: 4年前

内容简介:原先的结构是不断的写if/else,然后通过先符合条件如何进行返回,代码难以理解,并且大量的权限重复判断。

原先的结构是不断的写if/else,然后通过先符合条件如何进行返回,代码难以理解,并且大量的权限重复判断。

重构前代码

复杂的权限按钮控制优化
复杂的权限按钮控制优化

重构思路

  • 主要借鉴权限字典,进行配置型,而不是代码中分别写入赋值,任何需要的位置都可以重复使用,与当前解耦
  • 引入优先级属性,不用通过if/else的优先执行理解逻辑
  • 区分用户权限与业务状态,对于复杂的业务状态可以另外解耦独立出函数,与当前使用解耦
  • 操作对应的外界函数也按照属性进行配置,不定死
  • 通过使用过滤,一次性进行所有的过滤操作,省略不必要的一次次布尔型逻辑与和逻辑或的判断
  • 解耦渲染组件函数,可以根据菜单的数量以及业务需求,自定义如何渲染操作部分

思维导图图解

复杂的权限按钮控制优化

重构后代码示例

/*
* 判断是否能回放,权限判断复杂的都定义为函数,另外需要判断的其他外界条件建议封装为一个对象
*/
const canPlay = (lessonState)={return profile[519] && lessonState === 5}

/*
* 按钮操作字典,显示按钮的顺序按照下面的顺序排列
*/
const optDict=[{
name:'编辑课时',
key:1,
fn:editFn,
priv:profile[519]
},{
name:'录播回访',
key:2,
fn:playFn,
priv:canPlay()
},{
name:'顺延课程',
key:4,
fn:delayFn,
priv:profile[533]
}]

/*
* 权限判断的过滤方法
*/
const optDictFiltered = (optDict)=> return optDict.filter(opt => opt.priv)

const render = (optMenu)=>{
    let OPERATION = null;
    if(optMenu.length === 0){
        return OPERATION
    }
    if(optMenu.length === 1){
        let menu = optMenu[0]
        OPERATION = <button onClick={menu.fn}>{menu.name}</button>
        return OPERATION
    } else {
    let menu = optMenu[0];
    optMenu.unshift();
    let extraMenu = (
    <Menu>
    optMenu.map(item=><Menu.item key={item.key} >{item.name}</Menu.item)
    </Menu>
    );
         OPERATION = <dropdownbutton onClick={menu.fn} overlay={extraMenu}>
                {menu.name}</dropdownbutton>
    }
    
    return OPERATION
}

//最终使用
render(optDictFiltered(optDict))
复制代码

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

我的第一本编程书

我的第一本编程书

[日]平山尚 / 张沈宇 / 人民邮电出版社 / 2016-7 / 79.00元

写这本书之前,作者一直在摸索一种最有利于入门者学编程的方法,并应用到教学当中。经过两年的教学实践,他确信他的方法是有效的,于是便有了这本书。这本书面向的是完全没有接触过编程的读者。作者将门槛设置得非常低,读者不需要懂得变量、函数这些名词(这些名词在书中也不会出现),不需要会英语,完全不需要查阅其他书籍,只需要小学算术水平即可。这本书给初学者非常平缓的学习曲线,有利于为之后的进阶学习打下坚实的基础。一起来看看 《我的第一本编程书》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

html转js在线工具
html转js在线工具

html转js在线工具