JavaScript逻辑非运算符

JavaScript中的逻辑非(!)运算符是对一个表达式执行逻辑非操作。其结果是把表达式强制转换成true或false这两个结果。语法为result = !expression。表达式可以为字面量,函数,对象。

[javascript] view plain copy print ?
  1. <span style="font-size: 14px;">var aFalse = ['', 0, -0, null, false, NaN, undefined];
  2. for (var i in aFalse) {
  3. <span style="white-space: pre;"> </span>if (aFalse.hasOwnProperty(i)) {
  4. <span style="white-space: pre;"> </span>document.write(aFalse[i], '-', !aFalse[i], '-', !!aFalse[i], '<br />');
  5. <span style="white-space: pre;"> </span>}
  6. }</span>
var aFalse = ['', 0, -0, null, false, NaN, undefined];
for (var i in aFalse) {
	if (aFalse.hasOwnProperty(i)) {
		document.write(aFalse[i], '-', !aFalse[i], '-', !!aFalse[i], '<br />');
	}
}

在测试中如果一个对象定义之后对它使用逻辑运算,会返回true。需要注意的是Boolean包装类,当它自身返回一个false值,对这个变量执行逻辑非运算,所得到的并不是true,仍然为false。除非执行两次逻辑非操作。

[javascript] view plain copy print ?
  1. <span style="font-size: 14px;">var myObj = {}
  2. document.write(!myObj); // false
  3. document.write(!!myObj); // true
  4. var myBoolean = new Boolean(false);
  5. document.write(myBoolean); // false
  6. document.write(!myBoolean); // false
  7. document.write(!!myBoolean); //true;</span>
var myObj = {}
document.write(!myObj); // false
document.write(!!myObj); // true
var myBoolean = new Boolean(false);
document.write(myBoolean); // false
document.write(!myBoolean); // false
document.write(!!myBoolean); //true;

网络上给出的“如果应用于 undefined 或 null 表达式,则会产生一个运行时错误。 ”,在测试中会把它们转化成对应的布尔值,并没有产生错误。

JavaScript中把'', 0, -0, null, false, NaN, undefined在逻辑运算中理解为false,同样的,如果一个表达式的运算产生以上的任意一个结果,那么在逻辑运算中就会认为是false。下面的例子可以解释。


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值