if(xx)和 a==b的判断

1. if的判断

if(xxx){
}

对于小括号里的表达式,会被强制转换为布尔类型,具体情况如下表

类型 结果
Undefined false
Null false
Boolean 直接判断
Number +0, −0, 或者 NaN 为 false, 其他为 true
String 空字符串为 false,其他都为 true
Object true

根据以上表格我们来做点小练习

if (" ") {
    console.log("haha")
}
// 题目1:代码输出haha,因为空字符串为 false,其他都为 true,而上述代码是空白字符串,有一个空格

if ("") {
    console.log("haha")
}
// 题目2:代码不输出任何东西,因为空字符串为 false

if ([]) {
    console.log('haha')
}

// 题目3:代码输出haha,因为数组是一个Object对象,为ture,

2. == 的判断

对于==的判断,js的处理会更加复杂,具体如下表。

x y 结果
null undefined true
Number String x == toNumber(y) 将字符串转化为数字类型再判断
Boolean (any) toNumber(x) == y 将布尔类型转换为数字类型再判断
Object String or Number toPrimitive(x) == y
otherwise otherwise false

toNumber(数字类型的判断)

type Result
Undefined NaN
Null 0
Boolean ture -> 1, false -> 0
String “abc” -> NaN, “123” -> 123

toPrimitive

对于 Object 类型,先尝试调用 .valueOf 方法获取结果。 如果没定义,再尝试调用 .toString方法获取结果

根据以上说明我们来做点小练习

"" == 0  //题目1 数字和字符串判断,先将字符串转化为数字,空字符串和空白字符串转为数字0,所以为true。
" " == 0  //题目2 数字和字符串判断,同上理一样,所以为true。
"" == true  //题目3 先是布尔和任意类型判断,将布尔类型转化为数字型转 true转换为1 ,再将空字符串转换为0,所以为false.
!" " == true //题目4 因为空白字符串为true 所以 ! " " 为false  ,布尔类型直接判断所以为false。
!"" == true //题目5 因为空字符串为false 所以 ! " " 为true  ,布尔类型直接判断所以为true。
"hello" == true//题目6  "hello" 转换为数字NaN,true转换为数字1,NaN不等于任何数,所以为false。
"hello" == false//题目7  "hello" 转换为数字NaN,true转换为数字0,NaN不等于任何数,所以为false。
undefined == null//题目8  根据表格答案为true
var obj = { 
  a: 0, 
  valueOf: function(){return 1} 
} 
obj == "[object Object]"//题目9  函数valueOf方法返回值为1,字符串转换为数字类型NaN。所以为false。
obj == true //题目10  函数valueOf方法返回值为1,true转换为数字类型1。所以为false。

你可能感兴趣的:(if(xx)和 a==b的判断)