在javascript代码中经常会见到!!的情况,本文即以实例形式较为深入的分析javascript中2个感叹号的用法。分享给大家供大家参考之用。具体分析如下:
javascript中的!!是逻辑"非非",即是在逻辑“非”的基础上再"非"一次。通过!或!!可以将很多类型转换成bool类型,再做其它判断。
一、应用场景:判断一个对象是否存在
假设有这样一个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
4.对非零整型的"非"返回false
var temp=1; alert(temp);
结果:1
var temp=1; alert(!temp);
结果:false
var temp=1; alert(!!temp);
结果:true
5.对0的"非"返回true
var temp = 0; alert(temp);
结果:0
var temp = 0; alert(!temp);
结果:true
var temp = 0; alert(!!temp);
结果:false
6.对字符串的"非"返回false
var temp="ab"; alert(temp);
结果:ab
var temp="ab"; alert(!temp);
结果:false
var temp="ab"; alert(!!temp);
结果:true
7.对数组的"非"返回false
var temp=[1,2]; alert(temp);
结果:1,2
var temp=[1,2]; alert(!temp);
结果:false
var temp=[1,2]; alert(!!temp);
结果:true
相信本文所述对大家的javascript程序设计的学习有一定的借鉴价值。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。