一、AND详解:

  在JavaScript中,逻辑 AND 运算符用双和号(&&)表示。

  需要说明的是:逻辑AND运算的运算数可以是任何类型的,不止是Boolean值,如果某个运算数不是原始的Boolean型值,逻辑AND运算并不一定返回Boolean值

  逻辑AND运算符的运算行为如下:

  1. 如果一个运算数是对象,另一个是 Boolean 值,返回该对象。
  2. 如果两个运算数都是对象,返回第二个对象。
  3. 如果某个运算数是 null,返回 null。
  4. 如果某个运算数是 NaN,返回 NaN。
  5. 如果某个运算数是 undefined,发生错误。
  6. 如果两个运算数都是boolean类型,则返回boolean值

  与Java中的逻辑AND运算相似,JavaScript 中的逻辑AND运算也是简便运算,即如果第一个运算数决定了结果,就不再计算第二个运算数:即俗称的“短路规则”对于逻辑AND运算来说,如果第一个运算数是false,那么无论第二个运算数的值是什么,结果都不可能等于true。

  考虑下面的例子:

  1. var bTrue = true;
  2. var bResult = (bTrue && bUnknown); //发生错误
  3. alert(bResult); //这一行不会执行

  这段代码在进行逻辑 AND 运算时将引发错误,因为变量 bUnknown 是未定义的。变量 bTrue 的值为 true,因为逻辑 AND 运算将继续计算变量 bUnknown。这样做就会引发错误,因为 bUnknown 的值是 undefined,不能用于逻辑 AND 运算。如果修改这个例子,把第一个数设为 false,那么就不会发生错误:

  1. var bTrue = false;
  2. var bResult = (bTrue && bUnknown); //不会发生错误
  3. alert("bTrue && bUnknown的结果是:"+(bResult));//输出 "false"

  在这段代码中,脚本将输出逻辑AND运算返回的值,即字符串"false"。即使变量 bUnknown 的值为 undefined,它也不会被计算,因为第一个运算数的值是 false。

验证JavaScript逻辑And运算符的运算行为

  1. <script type="text/javascript">
  2. document.write("验证JavaScript逻辑And运算符的运算行为:");
  3. document.write("<br/>");
  4. document.write("-----------------------------------------------------------------------------");
  5. document.write("<br/>");
  6.  
  7. var bTrue = true;
  8. var bFalse = false;
  9. var bResult = bTrue && bFalse;
  10. /*1.如果两个运算数都是boolean类型,则返回boolean值*/
  11. document.write("1.如果两个运算数都是boolean类型,则返回boolean值");
  12. document.write("<br/>");
  13. document.write("-----------------------------------------------------------------------------");
  14. document.write("<br/>");
  15. document.write("bTrue = true,bFalse = false,bTrue && bFalse的结果是:"+(bResult));//结果为false
  16. document.write("<br/>");
  17. document.write("-----------------------------------------------------------------------------");
  18. document.write("<br/>");
  19.  
  20. var obj = new Object();
  21. /*2.如果一个运算数是对象,另一个是 Boolean 值,返回该对象*/
  22. document.write("2.如果一个运算数是对象,另一个是 Boolean 值,返回该对象");
  23. document.write("<br/>");
  24. document.write("-----------------------------------------------------------------------------");
  25. document.write("<br/>");
  26. document.write("obj是一个对象,true&&obj的结果是:"+(true && obj));//返回obj该对象
  27. document.write("<br/>");
  28. document.write("obj==true&&obj的结果是:"+(obj == (true && obj)));//判断obj与该对象相等,为true
  29. document.write("<br/>");
  30. document.write("false&&obj的结果是:"+(false && obj));//不执行后面,为false
  31. document.write("<br/>");
  32.  
  33. document.write("-----------------------------------------------------------------------------");
  34. document.write("<br/>");
  35. /*3.如果两个运算数都是对象,返回第二个对象。*/
  36. var obj1 = new Object();
  37. var obj2 = new Object();
  38. document.write("3.如果两个运算数都是对象,返回第二个对象。");
  39. document.write("<br/>");
  40. document.write("-----------------------------------------------------------------------------");
  41. document.write("<br/>");
  42. document.write("obj1是一个对象,obj2是一个对象,obj1==(obj1&&obj2)的结果是:"+(obj1 == (obj1 && obj2)));//obj1不等于obj2,结果为false
  43. document.write("<br/>");
  44. document.write("obj1是一个对象,obj2是一个对象,obj2==(obj1&&obj2)的结果是:"+(obj2 == (obj1 && obj2)));//obj2等于obj2,结果为true
  45. document.write("<br/>");
  46.  
  47. document.write("-----------------------------------------------------------------------------");
  48. document.write("<br/>");
  49. /*4.如果某个运算数是 null,返回null。*/
  50. var a = null;
  51. var b = true;
  52. document.write("4.如果某个运算数是 null,返回null。");
  53. document.write("<br/>");
  54. document.write("a=null,b=true,a&&b的结果是:"+( a && b ));
  55. document.write("<br/>");
  56. document.write("-----------------------------------------------------------------------------");
  57. document.write("<br/>");
  58. /*5.如果某个运算数是NaN,返回NaN*/
  59. var c = NaN;
  60. var d = "str";
  61. document.write("5.如果某个运算数是NaN,返回NaN");
  62. document.write("<br/>");
  63. document.write("c=NaN,d=str,c&&d的结果是:"+( c && d));
  64. document.write("<br/>");
  65. document.write("-----------------------------------------------------------------------------");
  66. document.write("<br/>");
  67. /*
  68. 6.JavaScript中的逻辑 AND 运算是简便运算,即如果第一个运算数决定了结果,就不再计算第二个运算数。
  69. 对于逻辑 AND 运算来说,如果第一个运算数是 false,那么无论第二个运算数的值是什么,结果都不可能等于 true。
  70. */
  71. var bFalse = false;
  72. var bResult = (bFalse && bUnknown);
  73. document.write("6.JavaScript中的逻辑 AND 运算是简便运算,即如果第一个运算数决定了结果,就不再计算第二个运算数");
  74. document.write("<br/>");
  75. document.write("对于逻辑 AND 运算来说,如果第一个运算数是 false,那么无论第二个运算数的值是什么,结果都不可能等于 true。");
  76. document.write("<br/>");
  77. document.write("bFalse=false,bUnknown是一个未定义的变量,bFalse && bUnknown的结果是:"+(bResult)); //输出 "false"
  78.  
  79. var bTrue = true;
  80. var bResult = (bTrue && bUnknown); //发生错误
  81. alert(bResult); //这一行不会执行
  82. </script>

二、OR详解:

  JavaScript的逻辑 OR 运算也是简便运算,对于逻辑 OR 运算符来说,如果第一个运算数值为 true,就不再计算第二个运算数,如果某个运算数不是 Boolean 值,逻辑 OR 运算并不一定返回 Boolean 值,逻辑||的运算规则如下:

  1. 如果一个运算数是对象,另一个是 Boolean 值,返回该对象。
  2. 如果两个运算数都是对象,返回第一个对象。(and是返回第二个对象)
  3. 如果某个运算数是 null,返回 null。
  4. 如果某个运算数是 NaN,返回 NaN。
  5. 如果某个运算数是 undefined,发生错误。

三、NOT详解:

  在JavaScript 中,逻辑NOT运算符与C和Java中的逻辑 NOT 运算符相同,都由感叹号(!)表示。与逻辑 OR 和逻辑 AND 运算符不同的是,逻辑 NOT 运算符返回的一定是 Boolean 值

逻辑 NOT 运算符的行为如下:

  • 如果运算数是对象,返回 false
  • 如果运算数是数字 0,返回 true
  • 如果运算数是 0 以外的任何数字,返回 false
  • 如果运算数是 null,返回 true
  • 如果运算数是 NaN,返回 true
  • 如果运算数是 undefined,发生错误
  1. <script type="text/javascript">
  2. var bFalse = false;//运算数是bool类型的数
  3. var sRed = "red";//运算数是字符串
  4. var iZero = ;//运算数是0
  5. var iThreeFourFive = ;//运算数是 0 以外的任何数字
  6. var oObject = new Object();//对象
  7. var oNull=null;//运算数是null
  8. var oUndefined;//运算数是undifined
  9. var oNaN=parseInt("abc");//使用parseInt方法把尝试字符串abc转换成整数,因为abc不是数字,因此是转不了的,所以返回的结果就是NaN
  10.  
  11. /*
  12. writeln() 方法与 write() 方法几乎一样,差别仅在于是前者将在所提供的任何字符串后添加一个换行符。在HTML中,这通常只会在后面产生一个空格;
  13. 不过如果使用了 <PRE> 和 <XMP> 标识,这个换行符会被解释,且在浏览器中显示。
  14. */
  15. document.writeln("<XMP>");
  16. document.writeln("oNaN=parseInt(\"abc\")返回的结果是"+oNaN);//NaN
  17. document.writeln("bool类型的数false与!运算符运算之后的结果是:" + (!bFalse));//true
  18. document.writeln("字符串sRed与!运算符运算之后的结果是: " + (!sRed));//false
  19. document.writeln("数字0与!运算符运算之后的结果是:" + (!iZero));//如果运算数是数字 0,返回 true
  20. document.writeln("数字345与!运算符运算之后的结果是:" + (!iThreeFourFive));//如果运算数是 0 以外的任何数字,返回 false
  21. document.writeln("对象oObject与!运算符运算之后的结果是:" + (!oObject));//如果运算数是对象,返回 false
  22. document.writeln("NaN与!运算符运算之后的结果是:" + (!oNaN));//如果运算数是NaN,返回 true
  23. document.writeln("null与!运算符运算之后的结果是:" + (!oNull));//如果运算数是 null,返回 true
  24. document.writeln("undifined与!运算符运算之后的结果是:" + (!oUndefined));//有定义,表示值是"undefined",返回 true
  25. //document.writeln("未定义的字符串sBule与!运算符运算之后的结果是:" + (!sBule));//sBule前面没有定义,也就是sBule运算数是 undefined,因此这里发生错误
  26. document.writeln("</XMP>");
  27. </script>

  判断JavaScript变量的Boolean 值时,也可以使用逻辑NOT运算符。这样做需要在一行代码中使用两个 NOT 运算符。无论运算数是什么类型,第一个NOT运算符返回 Boolean值,第二个NOT将对该Boolean值取反,从而给出变量真正的Boolean值。使用not运算符判断JavaScript变量的Boolean值是一个非常有用的技巧,只要知道了变量的boolean值,那么当使用变量进行 && 或者 || 运算时,就可以很快知道运算的结果了

  1. <script type="text/javascript">
  2. var bFalse = false;//运算数是bool类型的数
  3. var sRed = "red";//运算数是字符串
  4. var iZero = ;//运算数是0
  5. var iThreeFourFive = ;//运算数是 0 以外的任何数字
  6. var oObject = new Object();//对象
  7. var oNull=null;//运算数是null
  8. var oUndefined;//运算数是undifined
  9. var oNaN=parseInt("abc");//使用parseInt方法把尝试字符串abc转换成整数,因为abc不是数字,因此是转不了的,所以返回的结果就是NaN
  10. /*
  11. 判断JavaScript 变量的 Boolean 值时,也可以使用逻辑 NOT 运算符。这样做需要在一行代码中使用两个 NOT 运算符。
  12. 无论运算数是什么类型,第一个 NOT 运算符返回 Boolean 值。第二个 NOT 将对该 Boolean 值取反,从而给出变量真正的 Boolean 值。
  13. */
  14. document.write("<PRE>");
  15. document.writeln("布尔数false 的逻辑值是 " + (!!bFalse));
  16. document.writeln("字符串sRed 的逻辑值是 " + (!!sRed));
  17. document.writeln("数字0 的逻辑值是 " + (!!iZero));
  18. document.writeln("数字345 的逻辑值是 " + (!!iThreeFourFive));
  19. document.writeln("对象Object 的逻辑值是 " + (!!oObject));
  20. document.writeln("NaN的逻辑值是 :" + (!!oNaN));
  21. document.writeln("null 的逻辑值是 " + (!!oNull));
  22. document.writeln("undefined 的逻辑值是 " + (!!oUndefined));
  23. document.write("</PRE>");
  24. </script>

JavaScript逻辑and、or、not运算符详解的更多相关文章

  1. javascript event(事件对象)详解

    javascript event(事件对象)详解   1. 事件对象     1. 事件对象 Event 对象代表事件的状态,比如事件在其中发生的元素.键盘按键的状态.鼠标的位置.鼠标按钮的状态. 什 ...

  2. JavaScript调试技巧之console.log()详解

    JavaScript调试技巧之console.log()详解 对于JavaScript程序的调试,相比于alert(),使用console.log()是一种更好的方式,原因在于:alert()函数会阻 ...

  3. 转: javascript模块加载框架seajs详解

    javascript模块加载框架seajs详解 SeaJS是一个遵循commonJS规范的javascript模块加载框架,可以实现javascript的模块化开发和模块化加载(模块可按需加载或全部加 ...

  4. JavaScript中的鼠标滚轮事件详解

    JavaScript中的鼠标滚轮事件详解/*Firefox注册事件*/ ~~~Firefox: addEventListener('DOMMouseScroll', handler, false)if ...

  5. Net is as typeof 运行运算符详解 net 自定义泛型那点事

    Net is as typeof 运行运算符详解   概述 在了解运行运算符的前提我们需要了解什么是RTTI ,在任何一门面向对象的语言中,都有RTTI这个概念(即 运行时). RTTI(Run-Ti ...

  6. 《手把手教你》系列技巧篇(四十)-java+ selenium自动化测试-JavaScript的调用执行-下篇(详解教程)

    1.简介 在实际工作中,我们需要对处理的元素进行高亮显示,或者有时候为了看清楚做跟踪鼠标点击了哪些元素需要标记出来.今天宏哥就在这里把这种测试场景讲解和分享一下. 2.用法 创建一个执行 JS 的对象 ...

  7. JavaScript进阶知识点——函数和对象详解

    JavaScript进阶知识点--函数和对象详解 我们在上期内容中学习了JavaScript的基本知识点,今天让我们更加深入地了解JavaScript JavaScript函数 JavaScript函 ...

  8. JavaScript学习总结(三)——逻辑And运算符详解

    在JavaScript中,逻辑 AND 运算符用双和号(&&)表示 1 var bTrue = true; 2 var bFalse = false; 3 var bResult = ...

  9. Javascript设计模式之装饰者模式详解篇

    一.前言: 装饰者模式(Decorator Pattern):在不改变原类和继承的情况下动态扩展对象功能,通过包装一个对象来实现一个新的具有原对象相同接口的新的对象. 装饰者模式的特点: 1. 在不改 ...

随机推荐

  1. 久邦数码(3G门户)面试

    久邦数码(3G门户)面试 1.数组和链表的区别(为什么数组带有索引) 2.数据库(手写选出一个公司年龄最大的100个员工) 3.一百个数查找一个数 利用二分查找一个数在最差的情况下至少比较多少次 4. ...

  2. postman自动生成签名

    查看详细图文教程↓ 一.全局变量方式 1. 在全局变量添加key:value分别是autoSign和var sign={toUnicode:function(s){return s.replace(/ ...

  3. MNIST神经网络的训练

    import tensorflow as tf from tensorflow.examples.tutorials.mnist import input_data 1.设置输入和输出节点的个数,配置 ...

  4. Good Bye 2017 部分题解

    D. New Year and Arbitrary Arrangement 分析 \(dp[i][j]\) 表示已有 \(i\) 个 \(a\) 和 \(j\) 个 \(ab\) 的情况下继续构造能得 ...

  5. redis和mySql的数据同步的解析

    1.同步MySQL数据到Redis (1) 在redis数据库设置缓存时间,当该条数据缓存时间过期之后自动释放,去数据库进行重新查询,但这样的话,我们放在缓存中的数据对数据的一致性要求不是很高才能放入 ...

  6. redis_安装

    前面几章内容简单介绍了NoSql的概念,以及NoSql的几种分类,本文开始后面开始学习KV数据库Redis. 一.Redis是什么? Redis:REmote DIctionary Server(远程 ...

  7. web前端 -- onkeydown、onkeypress、onkeyup、onblur、onchange、oninput、onpropertychange的区别

    FROM:http://www.cnblogs.com/svage/archive/2011/11/15/2249954.html onkeydown:按下任何键(字母.数字.系统.tab等)都能触发 ...

  8. Codeforces Round #262 (Div. 2) E. Roland and Rose 暴力

    E. Roland and Rose Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 http://codeforces.com/problemset/pro ...

  9. Swify闭包

    闭包:是字包含的匿名函数代码块,可以做为表达式.函数参数和函数返回值,闭包表达式的运算结果是一种函数类型.类似于 C# Lambda 表达式. 闭包表达式: {(参数列表)->返回类型 in 语 ...

  10. intellj远程调试设置

    场景:本地intelllij想远程调试服务器A,服务器A上起得是resin服务 步骤: 1.登陆服务器A,给resin添加启动参数. 方法一:修改resin.xml,修改完后重启resin服务器 在r ...