js中if判断未生效

      先说结论,1.首先要注意0。 if(0)在js中,if的代码块是不会执行的。  2. java后台传来存在null的字段,假设  let test = null ; tyepeof  test ,输出的是 object,而不是undefined。  所以判断的时候 ,不要用 if (typeof  test != 'undefined' ),要写成 if (test != undefined )      

1. 第一个错误

      今天写了一段代码,有四个输入框,分别是上限值,上限范围(< 或 <=),下限值,下限范围( > 或 >=)。范围使用1、2代替。

      他们的关系是:有上限值必有上限范围,有下限值必有下限范围,反之亦然。必须有上限值或下限值,使用js判断。

// testUp - 上限值 , testUpRange - 上限范围 , testDown - 下限值 , testDownRange - 下限范围
if(testUp && !testUpRange){
    message.error("有上限值时必须填写上限值范围")
    return;
}
if(testDown && !testDownRange){
    message.error("有下限值时必须填写下限值范围")
    return;
}

if(!testUp && testUpRange){
    message.error("有上限范围时必须填写上限值")
    return;
}
if(!testDown && testDownRange){
    message.error("有下限范围时必须填写下限值")
    return;
}

if(!testUp && !testDown){
    message.error("必须填写上限或下限")
    return;
}

      输入一种情况:上限值20,上限范围<;下限值0,下限值范围未输入,未提示  “有下限值时必须填写下限范围”,并保存成功。

      首先输出testDown,testDownRange,发现testDown输出0,testDownRange输出null(后台-java传送的数据),以为js没有判断null,故编写以下代码:

if(!testDownRange){
    console.log(testDownRange)
}

      发现testDownRange 输出为 undefined,有点想不通,又编写以下代码:

if(testDown){
    console.log(testDown)
}

      发现没有输出testDown!!!! 

      突然想起来,testDown是0,js中,如果直接使用变量进行判断,即使该变量不是undefined,是0,也会判为false。

      以后做这种判断时切记!!!!!

 

 

2. 第二个错误

      代码改成下面的了:

        if( typeof testUp != 'undefined' && !testUpRange){
            message.error("有上限值时必须填写上限值范围")
            return;
        }
        if( typeof testDown != 'undefined'&& !testDownRange){
            message.error("有下限值时必须填写下限值范围")
            return;
        }

        if( typeof testUp == 'undefined'&& testUpRange){
            message.error("有上限范围时必须填写上限值")
            return;
        }
        if( typeof testDown == 'undefined'&& testDownRange){
            message.error("有下限范围时必须填写下限值")
            return;
        }

        if( typeof testUp == 'undefined'&& typeof testDown == 'undefined'){
            message.error("必须填写上限或下限")
            return;
        }
        if(!testUpRange && !testDownRange){
            message.error("必须填写上限范围或下限范围")
            return;
        }

      一条数据,有上限值和上限范围,没有下限值和下限范围。点击编辑,保存,发现提示: “有下限值时必须填写下限值范围”。

      后来测试发现, java后台传来的数据,testDown 和 testDownRange 的值都是null。

      假设 a = null, ! a 输出 true, 但是 typeof a 输出 'object'。 所以判断出问题了。要切记。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值