JavaScript学习总结(三)——逻辑And运算符详解
来源:互联网 发布:搜狐快站绑定独立域名 编辑:程序博客网 时间:2024/06/15 15:16
在JavaScript中,逻辑 AND 运算符用双和号(&&)表示
1 var bTrue = true;2 var bFalse = false;3 var bResult = bTrue && bFalse;
下面的真值表描述了逻辑AND运算符的行为:
运算数 1运算数 2结果truetruetruetruefalsefalsefalsetruefalsefalsefalsefalse
需要说明的是:逻辑AND运算的运算数可以是任何类型的,不止是Boolean值,如果某个运算数不是原始的Boolean型值,逻辑AND运算并不一定返回Boolean值
逻辑AND运算符的运算行为如下:
- 如果一个运算数是对象,另一个是 Boolean 值,返回该对象。
- 如果两个运算数都是对象,返回第二个对象。
- 如果某个运算数是 null,返回 null。
- 如果某个运算数是 NaN,返回 NaN。
- 如果某个运算数是 undefined,发生错误。
- 如果两个运算数都是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));//结果为false16 document.write("<br/>");17 18 document.write("-----------------------------------------------------------------------------");19 document.write("<br/>");20 21 var obj = new Object();22 /*2.如果一个运算数是对象,另一个是 Boolean 值,返回该对象*/23 document.write("2.如果一个运算数是对象,另一个是 Boolean 值,返回该对象");24 document.write("<br/>");25 document.write("-----------------------------------------------------------------------------");26 document.write("<br/>");27 document.write("obj是一个对象,true&&obj的结果是:"+(true&&obj));28 document.write("<br/>");29 document.write("obj==true&&obj的结果是:"+(obj==(true&&obj)));30 document.write("<br/>");31 document.write("false&&obj的结果是:"+(false&&obj));32 document.write("<br/>");33 34 document.write("-----------------------------------------------------------------------------");35 document.write("<br/>");36 /*3.如果两个运算数都是对象,返回第二个对象。*/37 var obj1 = new Object();38 var obj2 = new Object();39 document.write("3.如果两个运算数都是对象,返回第二个对象。");40 document.write("<br/>");41 document.write("-----------------------------------------------------------------------------");42 document.write("<br/>");43 document.write("obj1是一个对象,obj2是一个对象,obj1==(obj1&&obj2)的结果是:"+(obj1==(obj1&&obj2)));//结果为false44 document.write("<br/>");45 document.write("obj1是一个对象,obj2是一个对象,obj2==(obj1&&obj2)的结果是:"+(obj2==(obj1&&obj2)));//结果为true46 document.write("<br/>");47 48 document.write("-----------------------------------------------------------------------------");49 document.write("<br/>");50 /*4.如果某个运算数是 null,返回null。*/51 var a=null;52 var b=true;53 document.write("4.如果某个运算数是 null,返回null。");54 document.write("<br/>");55 document.write("a=null,b=true,a&&b的结果是:"+(a&&b));56 document.write("<br/>");57 document.write("-----------------------------------------------------------------------------");58 document.write("<br/>");59 /*5.如果某个运算数是NaN,返回NaN*/60 var c = NaN;61 var d = "str";62 document.write("5.如果某个运算数是NaN,返回NaN");63 document.write("<br/>");64 document.write("c=NaN,d=str,c&&d的结果是:"+(c&&d));65 document.write("<br/>");66 document.write("-----------------------------------------------------------------------------");67 document.write("<br/>");68 /*69 6.JavaScript中的逻辑 AND 运算是简便运算,即如果第一个运算数决定了结果,就不再计算第二个运算数。70 对于逻辑 AND 运算来说,如果第一个运算数是 false,那么无论第二个运算数的值是什么,结果都不可能等于 true。71 */72 var bFalse = false;73 var bResult = (bFalse && bUnknown);74 document.write("6.JavaScript中的逻辑 AND 运算是简便运算,即如果第一个运算数决定了结果,就不再计算第二个运算数");75 document.write("<br/>");76 document.write("对于逻辑 AND 运算来说,如果第一个运算数是 false,那么无论第二个运算数的值是什么,结果都不可能等于 true。");77 document.write("<br/>");78 document.write("bFalse=false,bUnknown是一个未定义的变量,bFalse && bUnknown的结果是:"+(bResult)); //输出 "false"79 80 var bTrue = true;81 var bResult = (bTrue && bUnknown); //发生错误82 alert(bResult); //这一行不会执行83 </script>
阅读全文
0 0
- JavaScript学习总结(三)——逻辑And运算符详解
- JavaScript学习总结(三)——逻辑And运算符详解
- JavaScript学习总结(三)——逻辑And运算符详解
- JavaScript学习总结(四)——逻辑OR运算符详解
- JavaScript学习总结(二)——逻辑Not运算符详解
- JavaScript学习总结(四)——逻辑OR运算符详解
- JavaScript学习总结(二)——逻辑Not运算符详解
- JavaScript学习总结(四)——逻辑OR运算符详解
- JavaScript学习总结(二)——逻辑Not运算符详解
- JavaScript学习总结(四)——逻辑OR运算符详解
- JavaScript学习总结(二)——逻辑Not运算符详解
- JavaScript学习总结(四)——逻辑OR运算符详解
- JavaScript中的三目运算符详解
- JavaScript逻辑非运算符
- 图像运算(六)——逻辑与(AND)
- Lua逻辑and和or的设计和三目运算符
- javaScript逻辑与操作符运算规则
- javaScript逻辑或操作符运算规则
- hashMap,hashTable,linkedHashMap,TreeMap
- MySQL5.6 主从复制
- 冒牌排序、快速排序、九九乘法表、菱形、三角形、倒立三角形、回数、素数
- Hibernate入门案例
- 通过PHP自带的$_SERVER判断 手机访问网站自动跳转到手机版
- JavaScript学习总结(三)——逻辑And运算符详解
- baidu map
- 好像叫单点登录吧?(自用)
- 436
- 用VS新建一个C++类
- python 获取地图信息
- mongo数据库的各种查询语句示例(比较全的)
- 函数数组
- 6种负载均衡算法