在JavaScript中,逻辑 AND 运算符用双和号(&&)表示
var bTrue = true; var bFalse = false; var bResult = bTrue && bFalse;
下面的真值表描述了逻辑AND运算符的行为:
需要说明的是:逻辑AND运算的运算数可以是任何类型的,不止是Boolean值,如果某个运算数不是原始的Boolean型值,逻辑AND运算并不一定返回Boolean值
逻辑AND运算符的运算行为如下:
与Java中的逻辑AND运算相似,JavaScript 中的逻辑AND运算也是简便运算,即如果第一个运算数决定了结果,就不再计算第二个运算数。对于逻辑AND运算来说,如果第一个运算数是false,那么无论第二个运算数的值是什么,结果都不可能等于true。
考虑下面的例子:
var bTrue = true; var bResult = (bTrue && bUnknown); //发生错误 alert(bResult); //这一行不会执行
代码运行结果:
这段代码在进行逻辑 AND 运算时将引发错误,因为变量 bUnknown 是未定义的。变量 bTrue 的值为 true,因为逻辑 AND 运算将继续计算变量 bUnknown。这样做就会引发错误,因为 bUnknown 的值是 undefined,不能用于逻辑 AND 运算。
如果修改这个例子,把第一个数设为 false,那么就不会发生错误:
var bTrue = false; var bResult = (bTrue && bUnknown); //不会发生错误 alert("bTrue && bUnknown的结果是:"+(bResult));//输出 "false"
在这段代码中,脚本将输出逻辑AND运算返回的值,即字符串"false"。即使变量 bUnknown 的值为 undefined,它也不会被计算,因为第一个运算数的值是 false。
运行结果:
验证JavaScript逻辑And运算符的运算行为
测试代码:
<script type="text/javascript"> document.write("验证JavaScript逻辑And运算符的运算行为:"); document.write("<br/>"); document.write("-----------------------------------------------------------------------------"); document.write("<br/>"); var bTrue = true; var bFalse = false; var bResult = bTrue && bFalse; /*1.如果两个运算数都是boolean类型,则返回boolean值*/ document.write("1.如果两个运算数都是boolean类型,则返回boolean值"); document.write("<br/>"); document.write("-----------------------------------------------------------------------------"); document.write("<br/>"); document.write("bTrue = true,bFalse = false,bTrue && bFalse的结果是:"+(bResult));//结果为false document.write("<br/>"); document.write("-----------------------------------------------------------------------------"); document.write("<br/>"); var obj = new Object(); /*2.如果一个运算数是对象,另一个是 Boolean 值,返回该对象*/ document.write("2.如果一个运算数是对象,另一个是 Boolean 值,返回该对象"); document.write("<br/>"); document.write("-----------------------------------------------------------------------------"); document.write("<br/>"); document.write("obj是一个对象,true&&obj的结果是:"+(true&&obj)); document.write("<br/>"); document.write("obj==true&&obj的结果是:"+(obj==(true&&obj))); document.write("<br/>"); document.write("false&&obj的结果是:"+(false&&obj)); document.write("<br/>"); document.write("-----------------------------------------------------------------------------"); document.write("<br/>"); /*3.如果两个运算数都是对象,返回第二个对象。*/ var obj1 = new Object(); var obj2 = new Object(); document.write("3.如果两个运算数都是对象,返回第二个对象。"); document.write("<br/>"); document.write("-----------------------------------------------------------------------------"); document.write("<br/>"); document.write("obj1是一个对象,obj2是一个对象,obj1==(obj1&&obj2)的结果是:"+(obj1==(obj1&&obj2)));//结果为false document.write("<br/>"); document.write("obj1是一个对象,obj2是一个对象,obj2==(obj1&&obj2)的结果是:"+(obj2==(obj1&&obj2)));//结果为true document.write("<br/>"); document.write("-----------------------------------------------------------------------------"); document.write("<br/>"); /*4.如果某个运算数是 null,返回null。*/ var a=null; var b=true; document.write("4.如果某个运算数是 null,返回null。"); document.write("<br/>"); document.write("a=null,b=true,a&&b的结果是:"+(a&&b)); document.write("<br/>"); document.write("-----------------------------------------------------------------------------"); document.write("<br/>"); /*5.如果某个运算数是NaN,返回NaN*/ var c = NaN; var d = "str"; document.write("5.如果某个运算数是NaN,返回NaN"); document.write("<br/>"); document.write("c=NaN,d=str,c&&d的结果是:"+(c&&d)); document.write("<br/>"); document.write("-----------------------------------------------------------------------------"); document.write("<br/>"); /* 6.JavaScript中的逻辑 AND 运算是简便运算,即如果第一个运算数决定了结果,就不再计算第二个运算数。 对于逻辑 AND 运算来说,如果第一个运算数是 false,那么无论第二个运算数的值是什么,结果都不可能等于 true。 */ var bFalse = false; var bResult = (bFalse && bUnknown); document.write("6.JavaScript中的逻辑 AND 运算是简便运算,即如果第一个运算数决定了结果,就不再计算第二个运算数"); document.write("<br/>"); document.write("对于逻辑 AND 运算来说,如果第一个运算数是 false,那么无论第二个运算数的值是什么,结果都不可能等于 true。"); document.write("<br/>"); document.write("bFalse=false,bUnknown是一个未定义的变量,bFalse && bUnknown的结果是:"+(bResult)); //输出 "false" var bTrue = true; var bResult = (bTrue && bUnknown); //发生错误 alert(bResult); //这一行不会执行 </script>
以上就是关于JavaScript逻辑And运算符的全部介绍,希望能够帮助到大家更好的学习js的逻辑运算符。
本文向大家介绍详解JavaScript逻辑Not运算符,包括了详解JavaScript逻辑Not运算符的使用技巧和注意事项,需要的朋友参考一下 在JavaScript 中,逻辑NOT运算符与C和Java中的逻辑 NOT 运算符相同,都由感叹号(!)表示。与逻辑 OR 和逻辑 AND 运算符不同的是,逻辑 NOT 运算符返回的一定是 Boolean 值。 逻辑 NOT 运算符的行为如下: 如果运算数
问题内容: 我对使用Python中的逻辑运算符获得的结果感到有些困惑。我是一个初学者,正在学习一些书籍,但是它们并没有像我所希望的那样详尽地解释。 这是我自己的代码: 似乎只是输出两个变量。 因此,我添加了另一个变量整数。然后我打印并得到以下输出: 后台Python到底是怎么回事?为什么输出的不是7或5、2之类的。 问题答案: Python布尔运算符返回最后计算的值,而不是True / False
逻辑运算符通常用于布尔型(逻辑)值。这种情况下,它们返回一个布尔值。然而,&& 和 || 运算符会返回一个指定操作数的值,因此,这些运算符也用于非布尔值。这时,它们也就会返回一个非布尔型值。—— MDN 逻辑运算符用于逻辑运算。如变量 num 要大于2同时也要小于 7,这里的同时就是一种逻辑运算。 JavaScript 中的逻辑运算有三种: && 与 (并且) || 或 (或者) ! 非 (取反)
本文向大家介绍javascript运算符——逻辑运算符全面解析,包括了javascript运算符——逻辑运算符全面解析的使用技巧和注意事项,需要的朋友参考一下 前面的话 逻辑运算符对操作数进行布尔运算,经常和关系运算符一样配合使用。逻辑运算符将多个关系表达式组合起来组成一个更复杂的表达式。逻辑运算符分为逻辑非'!'、逻辑与'&&'、逻辑或'||'3种,本文将介绍这三种逻辑运算符 逻辑非 逻辑非操作
本文向大家介绍JavaScript 逻辑非运算符(!),包括了JavaScript 逻辑非运算符(!)的使用技巧和注意事项,需要的朋友参考一下 示例 逻辑NOT(!)运算符对表达式执行逻辑取反。 语法: 返回值: 一个Boolean。 描述 逻辑NOT(!)运算符对表达式执行逻辑取反。 布尔值只需取反即可:!true === false和!false === true。 非布尔值首先转换为布尔值,
问题内容: 下面的两个语句是否等效? 和 我可以使用某种真值表来验证这一点吗? 问题答案: 优先于,因此,即使 与…不同 因为那将被执行为 并且想要使它们相同,是以下内容(使用括号覆盖优先级规则): 这是一个示例说明: