美文网首页
让 js 中的 if 判断如丝般顺滑

让 js 中的 if 判断如丝般顺滑

作者: 草帽lufei | 来源:发表于2021-10-09 16:37 被阅读0次

    项目中的一个小需求点,点击按钮,验证几十个条件框,判断所有条件框是否填写(选择)过数据(至少有一个条件判断为真)再执行对应操作

    判断的条件框包含 Radio 单选框,Checkbox 多选框,Input 输入框,InputNumber 计数器, Select 选择器, Switch 开关等

    项目使用的 Element 组件库 V2.15.6

    不同条件对应的数据类型以及默认值

    • Radio 单选框 string ''
    • Checkbox 多选框 array []
    • Input 输入框 string ''
    • InputNumber 计数器 number 0
    • Select 选择器
      • 单选 string ''
      • 多选 array []
    • Switch 开关 boolean false

    代码实现

    思路一

    直接用 if 判断开干,然后大概代码如下(变量为模拟变量)

    // 多条件判断开始,如下
    
    if (obj.radio1 || obj.checkbox1.length > 0 || obj.input1 || obj.inputNumber1 > 0 || obj.select1 || obj.select2.length > 0 || obj.switch1 || obj.radio2 || obj.checkbox2.length > 0 || obj.input2 || obj.inputNumber2 > 0 || obj.select3 || obj.select4.length > 0 || obj.switch2  ...) {
      // do something
    } else {
      // 条件不符,提示
      this.$message({
        message: '请选择条件后重试',
        type: 'warning'
      })
      return false
    } 
    

    实际项目场景中的变量名因为语义化字符很多, if 判断没写几个就写了很长一串, 然后写了几个就写不动了(感觉在写一坨 shi )

    能不能用更优雅的方式实现呢?
    思路二

    把这些需要判断的变量放到一个数组里,用 map 处理成 Boolean 类型,使用 includes 判断数组中是否包含指定的 Boolean

    // 多条件判断开始,如下
    
    const arr = [
      obj.radio1,
      obj.checkbox1.length,
      obj.input1,
      obj.inputNumber1,
      obj.select1,
      obj.select2.length,
      obj.switch1,
      obj.radio2,
      obj.checkbox2.length,
      obj.input2,
      obj.inputNumber2,
      obj.select3,
      obj.select4.length,
      obj.switch2 
      ...
    ]
    
    const arr1 = arr.map(item => Boolean(item))
    if (arr1.includes(true)) {
      // do something
    } else {
      // 条件不符,提示
      this.$message({
        message: '请选择条件后重试',
        type: 'warning'
      })
      return false
    } 
    

    好了,if 处理大量判断用这种方式使是不是更丝滑了 ^-^

    参考文档

    https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Boolean

    https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Array/map

    https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Array/includes

    如果喜欢,顺手点个赞再走呗 ^-^

    相关文章

      网友评论

          本文标题:让 js 中的 if 判断如丝般顺滑

          本文链接:https://www.haomeiwen.com/subject/smsenltx.html