在javascript代码中经常会见到!!的情况,在实际应用中要具体分析变量类型,现在用实际详细讲讲双!!双感叹号的用处。
主要作用:js中两个 !! 号的意思是将变量等于 0、undefind、unll、空字符 强制转换为 Boolean 类型,却变量A为等于 0、undefind、unll、空字符,console.log(!!A)出来都是为flase。
具体分析如下:
javascript中的!!是逻辑"非非",即是在逻辑“非”的基础上再"非"一次。通过!或!!可以将很多类型转换成bool类型,再做其它判断。
使用javascript时,有时会在变量前面加上两个感叹号,这样做表示什么含义呢?Javascript中,!表示运算符“非”,如果变量不是布尔类型,会将变量自动转化为布尔类型,再取非,那么用两个!!就可以将变量转化为对应布尔值。
一、应用场景:判断一个对象是否存在
假设有这样一个json对象:
{ color: "#E3E3E3", "font-weight": "bold" }1
需要判断是否存在,用!!再好不过。
如果仅仅打印对象,无法判断是否存在:
var temp = { color: "#A60000", "font-weight": "bold" };alert(temp);12
结果:[object: Object]
如果对json对象实施!或!!,就可以判断该json对象是否存在:
var temp = { color: "#A60000", "font-weight": "bold" };alert(!temp);12
结果:false
var temp = { color: "#A60000", "font-weight": "bold" };alert(!!temp);12
结果:true
二、通过!或!!把各种类型转换成bool类型的惯例
1.对null的"非"返回true
var temp = null;alert(temp);12
结果:null
var temp = null;alert(!temp);12
结果:true
var temp = null;alert(!!temp);12
结果:false
2.对undefined的"非"返回true
var temp;alert(temp);12
结果:undefined
var temp;alert(!temp);12
结果:true
var temp;alert(!!temp);12
结果:false
3.对空字符串的"非"返回true
var temp="";alert(temp);12
结果:空
var temp="";alert(!temp);12
结果:true
var temp="";alert(!!temp);12
结果:false
4.对非零整型的"非"返回false
var temp=1;alert(temp);12
结果:1
var temp=1;alert(!temp);12
结果:false
var temp=1;alert(!!temp);12
结果:true
5.对0的"非"返回true
var temp = 0;alert(temp);12
结果:0
var temp = 0;alert(!temp);12
结果:true
var temp = 0;alert(!!temp);12
结果:false
6.对字符串的"非"返回false
var temp="ab";alert(temp);12
结果:ab
var temp="ab";alert(!temp);12
结果:false
var temp="ab";alert(!!temp);12
结果:true
7.对数组的"非"返回false
var temp=[1,2];alert(temp);12
结果:1,2
var temp=[1,2];alert(!temp);12
结果:false
var temp=[1,2];alert(!!temp);12
结果:true