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

2018-04-24  本文已影响0人  蔡森屿

if的判断

1.if(number)
if后的括号里的表达式会被强制转换为布尔类型

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

例:当 if(number),0、NaN为false,其他值为true

var a = 5
if(a){
    console.log('true')
} // true
a = 1
if(a){
    console.log('true')
} // true
a = 0
if(a){
    console.log('true')
} // false
a = -1
if(a){
    console.log('true')
} //false
a = NaN
if(a){
    console.log('true')
} //false

2.if(string)
当 if(string),空字符串为false,其他为true

if('hello'){
    console.log('true')
} // true
if('   '){
    console.log('true')
} // true
if(''){
    console.log('true')
} // false
if('0.00'){
    console.log('true')
}//true

3.if(boolean)
当 if(boolean),直接判断

if(true){
    console.log('true')
} // true
if(false){
    console.log('true')
} // false

4.if(object)
当 if(object),为true

if([1,3,4]){
    console.log('true')
} // true
function f(){
   var b = 1 + 2;
   return b; 
}
if(f()){
    console.log('true')
} //true

5.if(undefined)
当 if(undefined),为false

if(undefined){
    console.log('true')
} //false

6.if(null)
当 if(null),为false

if(null){
    console.log('true')
} //false

a == b 的判断

对于相同类型的a、b,相等的判断较简单。以下主要讨论不同数据类型的a、b之间进行相等运算时的判断。

  1. string == number
    结果为 toNumber(a) == b ,当a无法转换为number时判断相等为false

"" == 0 //true
" " == 0 //true
"hello" == 0 //false
"hello" == 1 //false
"2" == 2 //true

  1. boolean == (any)
    Boolean在相等运算时会转换为数值,true为1,false为0。

"" == true //false
"" == false //true
" " == true //false
"hello" == true //false
1 == true //true
0 == false //true
undefined == false //false
undefined == true //false
null == false //false
null == true //false

  1. object == number/string
    object会试图使用valueOf和toString转换后比较

var obj = {
a: 0,
valueOf: function(){return 1}
}
obj == 1 //true
[] == 0 //true
[2] == 2 //true

  1. null == undefined //true

toNumber
undefined --> NaN
null --> 0
boolean --> true:1, false:0
string --> "abc":NaN,"123":123

总结:

做相等运算时,一般倾向于将不同的数据类型都转化为数值,或是转化为相同的数据类型.

上一篇 下一篇

猜你喜欢

热点阅读