JS中!!的用法

在javascript代码中经常会见到!!的情况,本文即以实例形式较为深入的分析javascript中2个感叹号的用法。分享给大家供大家参考之用。具体分析如下:

javascript中的!!是逻辑"非非",即是在逻辑“非”的基础上再"非"一次。通过!或!!可以将很多类型转换成bool类型,再做其它判断。

使用javascript时,有时会在变量前面加上两个感叹号,这样做表示什么含义呢?Javascript中,!表示运算符“非”,如果变量不是布尔类型,会将变量自动转化为布尔类型,再取非,那么用两个!!就可以将变量转化为对应布尔值。

一、应用场景:判断一个对象是否存在

假设有这样一个json对象:

{ color: "#E3E3E3", "font-weight": "bold" } 

需要判断是否存在,用!!再好不过。

如果仅仅打印对象,无法判断是否存在:

var temp = { color: "#A60000", "font-weight": "bold" };  alert(temp); 

结果:[object: Object]

如果对json对象实施!或!!,就可以判断该json对象是否存在

var temp = { color: "#A60000", "font-weight": "bold" };  alert(!temp); 

结果:false

var temp = { color: "#A60000", "font-weight": "bold" };  alert(!!temp); 

结果:true

二、通过!或!!把各种类型转换成bool类型的惯例

1.对null的"非"返回true

var temp = null;  alert(temp); 

结果:null

var temp = null;  alert(!temp);  

结果:true

var temp = null;  alert(!!temp);  

结果:false

2.对undefined的"非"返回true

var temp;  alert(temp); 

结果:undefined

var temp;  alert(!temp); 

结果:true

var temp;  alert(!!temp); 

结果:false

3.对空字符串的"非"返回true

var temp="";  alert(temp); 

结果:空

var temp="";  alert(!temp); 

结果:true

var temp="";  alert(!!temp); 

结果:false

等等。

总结:

!可将变量转换成boolean类型,0,null,undefined和空字符串通过 !取反 就是ture,否则就是false。

转自csdn,作者:红孩儿2011,点我

点此发表评论
暂无评论