在JavaScript中,逻辑OR运算符用||表示
var bTrue = true; var bFalse = false; var bResult = bTrue || bFalse;
下面的真值表描述了逻辑AND运算符的行为:
在JavaScript中,0,"",false,null,undefined,NaN均表示false,
可以用如下的代码证明:
<script type="text/javascript"> var bFalse = false;//bool类型 var strEmpty = "";//空字符串 var iZero = ;//数是 var oNull=null;//null var oUndefined;//undifined var oNaN=NaN;//NaN /* 判断JavaScript 变量的 Boolean 值时,也可以使用逻辑 NOT 运算符。这样做需要在一行代码中使用两个 NOT 运算符。 无论运算数是什么类型,第一个 NOT 运算符返回 Boolean 值。第二个 NOT 将对该 Boolean 值求负,从而给出变量真正的 Boolean 值。 */ document.write("<PRE>"); document.writeln("布尔数false的逻辑值是 " + (!!bFalse)); document.writeln("空字符串(\"\")的逻辑值是 " + (!!strEmpty)); document.writeln("数字的逻辑值是 " + (!!iZero)); document.writeln("NaN的逻辑值是 :" + (!!oNaN)); document.writeln("null的逻辑值是 " + (!!oNull)); document.writeln("undefined的逻辑值是 " + (!!oUndefined)); document.write("</PRE>"); </script>
运行结果:
JavaScript的逻辑 OR 运算也是简便运算,对于逻辑 OR 运算符来说,如果第一个运算数值为 true,就不再计算第二个运算数,如果某个运算数不是 Boolean 值,逻辑 OR 运算并不一定返回 Boolean 值,逻辑||的运算规则如下:
1.如果一个运算数是对象,另一个是 Boolean 值,返回该对象。
2.如果两个运算数都是对象,返回第一个对象。
3.如果某个运算数是 null,返回 null。
4.如果某个运算数是 NaN,返回 NaN。
5.如果某个运算数是 undefined,发生错误。
对于这些运算规则,没有必要死记硬背,因为在JavaScript中,可以使用逻辑Not运算符来判断JavaScript变量的Boolean值,判断的方式就是"!!变量名",例如:
使用逻辑Not运算符来判断JavaScript变量的Boolean值
<script type="text/javascript"> var bFalse = false;//运算数是bool类型的数 var sRed = "red";//运算数是字符串 var iZero = ;//运算数是 var iThreeFourFive = ;//运算数是 以外的任何数字 var oObject = new Object();//对象 var oNull=null;//运算数是null var oUndefined;//运算数是undifined var oNaN=parseInt("abc");//使用parseInt方法把尝试字符串abc转换成整数,因为abc不是数字,因此是转不了的,所以返回的结果就是NaN /* 判断JavaScript 变量的 Boolean 值时,也可以使用逻辑 NOT 运算符。这样做需要在一行代码中使用两个 NOT 运算符。 无论运算数是什么类型,第一个 NOT 运算符返回 Boolean 值。第二个 NOT 将对该 Boolean 值取反,从而给出变量真正的 Boolean 值。 */ document.write("<PRE>"); document.writeln("布尔数false 的逻辑值是 " + (!!bFalse)); document.writeln("字符串sRed 的逻辑值是 " + (!!sRed)); document.writeln("数字 的逻辑值是 " + (!!iZero)); document.writeln("数字 的逻辑值是 " + (!!iThreeFourFive)); document.writeln("对象Object 的逻辑值是 " + (!!oObject)); document.writeln("NaN的逻辑值是 :" + (!!oNaN)); document.writeln("null 的逻辑值是 " + (!!oNull)); document.writeln("undefined 的逻辑值是 " + (!!oUndefined)); document.write("</PRE>"); </script>
判断结果:
逻辑||运算符测试脚本:
<script type="text/javascript"> document.write("<PRE>"); /*JavaScript中的||将返回第一个不为false的那个值(对象亦可)或者最后一个值(如果全部都为false的话)*/ var a=; var b=; var c=a||b;//在JavaScript中,非的数字就代表true,就代表false document.writeln("a=,b=,c=a||b的结果是:"+c);//结果为,返回第一个不为false的那个值,所以值是 var bFalse=false; var bFalse=false; var num=;//代表false var result=bFalse||bFalse||num; document.writeln("bFalse=false,bFalse=false,num=,result=bFalse||bFalse||num的结果是:"+num);//如果全部都为false的话,返回最后一个值,因此结果是 /*如果一个运算数是对象,另一个是 Boolean 值,返回该对象。*/ var obj = new Object(); var bTrue=true; var bFalse=false; document.writeln("obj||bTrue的结果是:"+(obj||bTrue));//返回object document.writeln("bTrue||obj的结果是:"+(bTrue||obj));//返回true,逻辑 OR 运算也是简便运算。对于逻辑 OR 运算符来说,如果第一个运算数值为 true,就不再计算第二个运算数。 document.writeln("obj||bFalse的结果是:"+(obj||bFalse));//返回object document.writeln("bFalse||obj的结果是:"+(bFalse||obj));//返回object /*如果两个运算数都是对象,返回第一个对象*/ var obj = new Object(); var obj = new Object(); document.writeln("obj==(obj||obj)的结果是:"+(obj==(obj||obj)));//结果为true document.writeln("obj==(obj||obj)的结果是:"+(obj==(obj||obj)));//结果为false /*如果某个运算数是 null,返回 null。*/ var c=; var d=null; document.writeln("d=null,null的布尔值是;"+(!!d)); document.writeln("c=,d=null,c||d的结果是:"+(c||d)); document.writeln("c=,d=null,d||c的结果是:"+(d||c)); var o=new Object(); document.writeln("o是一个对象,d=null,o||d的结果是:"+(o||d));//返回object document.writeln("o是一个对象,d=null,d||o的结果是:"+(d||o));//返回object var zero=; document.writeln("zero=,d=null,zero||d的结果是:"+(zero||d));//返回null document.writeln("zero=,d=null,d||zero的结果是:"+(d||zero));//返回 var bTrue = true; var bResult = (bTrue || bUnknown); /*变量 bUnknown 是未定义的。不过,由于变量 bTrue 的值为 true,bUnknown 不会被计算,因此输出的是 "true"。*/ document.writeln("bUnknown是未定义的一个变量,bResult = (bTrue || bUnknown)的结果是:"+bResult);//输出 "true" bFalse = false; bResult = (bFalse || bUnknown); //发生错误 document.writeln(bResult); //不会执行这一行 document.write("</PRE>");
运行结果:
以上内容是小编给大家介绍的JavaScript知识点总结(四)之逻辑OR运算符详解,希望对大家有所帮助!
本文向大家介绍JavaScript逻辑运算符相关总结,包括了JavaScript逻辑运算符相关总结的使用技巧和注意事项,需要的朋友参考一下 前言 关于 JavaScript 中的逻辑运算符,我们经常使用却可能不知道它的一些机制和用法。 机制 首先我们需要知道几种逻辑运算符的优先级是不同的(关于完整的运算符优先级,看运算符优先级),逻辑非>逻辑与>逻辑或>条件运算符(三目运算符)。运算顺序条件运算符
本文向大家介绍详解JavaScript逻辑And运算符,包括了详解JavaScript逻辑And运算符的使用技巧和注意事项,需要的朋友参考一下 在JavaScript中,逻辑 AND 运算符用双和号(&&)表示 下面的真值表描述了逻辑AND运算符的行为: 需要说明的是:逻辑AND运算的运算数可以是任何类型的,不止是Boolean值,如果某个运算数不是原始的Boolean型值,逻辑AND运算并不
本文向大家介绍详解JavaScript逻辑Not运算符,包括了详解JavaScript逻辑Not运算符的使用技巧和注意事项,需要的朋友参考一下 在JavaScript 中,逻辑NOT运算符与C和Java中的逻辑 NOT 运算符相同,都由感叹号(!)表示。与逻辑 OR 和逻辑 AND 运算符不同的是,逻辑 NOT 运算符返回的一定是 Boolean 值。 逻辑 NOT 运算符的行为如下: 如果运算数
逻辑运算符通常用于布尔型(逻辑)值。这种情况下,它们返回一个布尔值。然而,&& 和 || 运算符会返回一个指定操作数的值,因此,这些运算符也用于非布尔值。这时,它们也就会返回一个非布尔型值。—— MDN 逻辑运算符用于逻辑运算。如变量 num 要大于2同时也要小于 7,这里的同时就是一种逻辑运算。 JavaScript 中的逻辑运算有三种: && 与 (并且) || 或 (或者) ! 非 (取反)
本文向大家介绍JavaScript 逻辑非运算符(!),包括了JavaScript 逻辑非运算符(!)的使用技巧和注意事项,需要的朋友参考一下 示例 逻辑NOT(!)运算符对表达式执行逻辑取反。 语法: 返回值: 一个Boolean。 描述 逻辑NOT(!)运算符对表达式执行逻辑取反。 布尔值只需取反即可:!true === false和!false === true。 非布尔值首先转换为布尔值,
本文向大家介绍总结Python中逻辑运算符的使用,包括了总结Python中逻辑运算符的使用的使用技巧和注意事项,需要的朋友参考一下 下表列出了所有Python语言支持的逻辑运算符。假设变量a持有10和变量b持有20,则: 示例: 试试下面的例子就明白了所有的Python编程语言提供了逻辑运算符: 当执行上面的程序它会产生以下结果: