时间:2021-05-26
在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程序设计的学习有一定的借鉴价值。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
一、lazada产品创建上传2、已经上线的SKU如果有修改内容,产品状态会变为感叹号,感叹号期间不影响销售,会继续在前台以修改之前的内容展示,修改后的内容需要等
一、使用感叹号PPC行业众所周知,感叹号可以提高点击率。为什么?也许是因为感叹号提高了你的声音,使你更容易引起别人的注意。在SEO的标题中尝试这个方法。虽然感叹
以windows7系统的电脑为例,电脑右下角的网络控制器出现感叹号的原因如下: 1、网络连接故障,导致出现感叹号,无法上网。 2、DNS或者IP错误,导致出
wifi信号旁边有个感叹号是指该wifi源没有通过安全加密,是不用密码就能连接的信号源。解决Wifi感叹号的步骤: 1、无线路由器插上电,先不要接猫,把无线路
JS中function的开头有必要加分号吗?js语句后应该加分号吗?javascript大括号后面应使用分号吗?JS中function的开头有加感叹号、分号是什