九镑十七便士 2023-02-17 09:25 采纳率: 30.6%
浏览 44

两层if嵌套该怎么优化


pushData(flag) {
      const { $refs } = this;
      if (flag === REMAINING_SHAREHOLDERS) {
        if ($refs[flag].getData().length <= DYNAMIC_NUM) {
          $refs[flag].pushData({});
        }
      } else {
        $refs[flag].pushData({});
      }
    },

请问以上代码该怎么优化,主要针对内部的两层if嵌套

  • 写回答

6条回答 默认 最新

  • MarkHan_ 2023-02-17 09:32
    关注

    可以考虑使用更简洁的逻辑条件表达式(ternary operator)代替嵌套的if语句。

    例如,可以将原来的代码改写成:

    pushData(flag) {
      const { $refs } = this;
      const dataLength = $refs[flag].getData().length;
      if (flag === REMAINING_SHAREHOLDERS && dataLength <= DYNAMIC_NUM) {
        $refs[flag].pushData({});
      } else if (flag !== REMAINING_SHAREHOLDERS) {
        $refs[flag].pushData({});
      }
    }
    

    这样可以将嵌套的if语句简化为两个逻辑条件表达式,使代码更加简洁易懂。

    评论

报告相同问题?

问题事件

  • 创建了问题 2月17日

悬赏问题

  • ¥15 ArcGIS批量裁剪
  • ¥15 labview程序设计
  • ¥15 为什么在配置Linux系统的时候执行脚本总是出现E: Failed to fetch http:L/cn.archive.ubuntu.com
  • ¥15 Cloudreve保存用户组存储空间大小时报错
  • ¥15 伪标签为什么不能作为弱监督语义分割的结果?
  • ¥15 编一个判断一个区间范围内的数字的个位数的立方和是否等于其本身的程序在输入第1组数据后卡住了(语言-c语言)
  • ¥15 游戏盾如何溯源服务器真实ip?
  • ¥15 Mac版Fiddler Everywhere4.0.1提示强制更新
  • ¥15 android 集成sentry上报时报错。
  • ¥50 win10链接MySQL