在javascript代码中经常会见到!!的情况,本文即以实例形式较为深入的分析javascript中2个感叹号的用法。分享给大家供大家参考之用。具体分析如下:
javascript中的!!是逻辑"非非",即是在逻辑“非”的基础上再"非"一次。通过!或!!可以将很多类型转换成bool类型,再做其它判断。
一、应用场景:判断一个对象是否存在
假设有这样一个json对象:
1
|
{ color:
"#E3E3E3"
,
"font-weight"
:
"bold"
}
|
需要判断是否存在,用!!再好不过。
如果仅仅打印对象,无法判断是否存在:
1
2
|
var
temp = { color:
"#A60000"
,
"font-weight"
:
"bold"
};
alert(temp);
|
结果:[object: Object]
如果对json对象实施!或!!,就可以判断该json对象是否存在:
1
2
|
var
temp = { color:
"#A60000"
,
"font-weight"
:
"bold"
};
alert(!temp);
|
结果:false
1
2
|
var
temp = { color:
"#A60000"
,
"font-weight"
:
"bold"
};
alert(!!temp);
|
结果:true
二、通过!或!!把各种类型转换成bool类型的惯例
1.对null的"非"返回true
1
2
|
var
temp =
null
;
alert(temp);
|
结果:null
1
2
|
var
temp =
null
;
alert(!temp);
|
结果:true
1
2
|
var
temp =
null
;
alert(!!temp);
|
结果:false
2.对undefined的"非"返回true
1
2
|
var
temp;
alert(temp);
|
结果:undefined
1
2
|
var
temp;
alert(!temp);
|
结果:true
1
2
|
var
temp;
alert(!!temp);
|
结果:false
3.对空字符串的"非"返回true
1
2
|
var
temp=
""
;
alert(temp);
|
结果:空
1
2
|
var
temp=
""
;
alert(!temp);
|
结果:true
1
2
|
var
temp=
""
;
alert(!!temp);
|
结果:false
4.对非零整型的"非"返回false
1
2
|
var
temp=1;
alert(temp);
|
结果:1
1
2
|
var
temp=1;
alert(!temp);
|
结果:false
1
2
|
var
temp=1;
alert(!!temp);
|
结果:true
5.对0的"非"返回true
1
2
|
var
temp = 0;
alert(temp);
|
结果:0
1
2
|
var
temp = 0;
alert(!temp);
|
结果:true
1
2
|
var
temp = 0;
alert(!!temp);
|
结果:false
6.对字符串的"非"返回false
1
2
|
var
temp=
"ab"
;
alert(temp);
|
结果:ab
1
2
|
var
temp=
"ab"
;
alert(!temp);
|
结果:false
1
2
|
var
temp=
"ab"
;
alert(!!temp);
|
结果:true
7.对数组的"非"返回false
1
2
|
var
temp=[1,2];
alert(temp);
|
结果:1,2
1
2
|
var
temp=[1,2];
alert(!temp);
|
结果:false
1
2
|
var
temp=[1,2];
alert(!!temp);
|
结果:true