关键词搜索

全站搜索
×
密码登录在这里
×
注册会员

已有账号? 请点击

忘记密码

已有账号? 请点击

使用其他方式登录

javascript js中!!(双感叹号)号用法和作用

发布2023-07-05 浏览423次

详情内容

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

使用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

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



1.对数字

var temp=1;
alert(temp);  // 结果:1
var temp=1;
alert(!temp);  // 结果:false
var temp=1;
alert(!!temp);  // 结果:true

2.零

var temp = 0;
alert(temp);  // 结果:0
var temp = 0;
alert(!temp);  // 结果:true
var temp = 0;
alert(!!temp);  // 结果:false


对字符串

非空字符串

var temp="ab";
alert(temp);  // 结果:ab
var temp="ab";
alert(!temp);  // 结果:false
var temp="ab";
alert(!!temp);  // 结果:true

空字符串

var temp="";
alert(temp);  // 结果:空
var temp="";
alert(!temp);  // 结果:true
var temp="";
alert(!!temp);  // 结果:false

对数组

var temp=[1,2];
alert(temp);  // 结果:1,2
var temp;
alert(!temp);  // 结果:true
var temp=[1,2];
alert(!!temp);  // 结果:true

总结:javascript中的!!是逻辑"非非"可以很方法判断一个变量var a, 是否为空串,nullundefined

点击QQ咨询
开通会员
上传资源赚钱
返回顶部
×
  • 微信支付
  • 支付宝付款
扫码支付
微信扫码支付
请使用微信描二维码支付
×

提示信息

×

选择支付方式

  • 微信支付
  • 支付宝付款
确定支付下载