JavaScript中的逻辑非(!)运算符是对一个表达式执行逻辑非操作。其结果是把表达式强制转换成true或false这两个结果。语法为result = !expression。表达式可以为字面量,函数,对象。
- <span style="font-size: 14px;">var aFalse = ['', 0, -0, null, false, NaN, undefined];
- for (var i in aFalse) {
- <span style="white-space: pre;"> </span>if (aFalse.hasOwnProperty(i)) {
- <span style="white-space: pre;"> </span>document.write(aFalse[i], '-', !aFalse[i], '-', !!aFalse[i], '<br />');
- <span style="white-space: pre;"> </span>}
- }</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。除非执行两次逻辑非操作。
- <span style="font-size: 14px;">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;</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。下面的例子可以解释。