代码存在大量的if/else优化方案总结

2021-06-25  本文已影响0人  Grit_1024
过多的else if 会使代码臃肿而简陋,下面是优化方案总结

一、多个else if分支优化

1.Key-value的方式,通过操作相关联的键值

优化前:

    if ((A = 10)) {
      rule.id = "a";
    } else if ((B = 100)) {
      rule.id = "b";
    } else {
      rule.id = "c";
    }

优化后:

    let player = {
      A: "a",
      B: "b",
      无: "c",
    };
    player[A] ? player[B] : player["无"];
2.new Map替代if else
    let key = "B"; //条件
    let player = new Map([
      ["A", "a"],
      ["B", "b"],
      ["无", "c"],
    ]);
    let action = player.get(key) || player.get("无");
    console.log(action);//b
 
    //     const actions = new Map([
    //     ['guest_1', () => { functionA }],
    //     ['guest_2', () => {  functionB }],
    //     ['guest_3', () => { functionC }],
    //     ['guest_4', () => { functionA }],
    //     ['default', () => { functionC  }],
    // ])
    // console.log(actions);

二、单个if多条件优化

优化前:

function test(type) {
  if (type === 'jpg' || type === 'png' || type === 'gif' || type === 'svg') {
    console.log("该文件为图片");
  }
}

优化后:

function test(type) {
    const imgArr = ['jpg', 'png', 'gif', 'svg']
    if (imgArr.includes(type)) {
        console.log("该文件为图片")
    }
}

三、if/else语句优化

排非策略
优化前:

 if (user && password) {
        // 逻辑处理
    } else {
        throw('用户名和密码不能为空!')
    }

优化后:

if (!user || !password) return throw('用户名和密码不能为空!')

三元运算符
优化前:

let allow = null
if(id>=10 ){ 
   allow = '通过'; 
} else { 
   allow = '拒绝'; 
}

// 优化后
let allow = id>=10  ? '通过' : '拒绝'

四、单个if语句优化

优化前:

if (a) {
 this.handleFn()
}

优化后

flag && this.handleFn()

上一篇 下一篇

猜你喜欢

热点阅读