此文章转载自http://blog.csdn.net/xiaotao_css/article/details/61940664

一、先来说说 ||(逻辑或),从字面上来说,只有前后都是false的时候才返回false,否则返回true。

alert(true||false);    // true
alert(false||true); // true
alert(true||true); // true
alert(false||false); // false

但是,从深层意义上来说的话,却有另一番天地,试看下面代码:

alert(0||1);

显然,我们知道,前面0意味着false,而后面1意味着true,那么上面的结果应该是true,而事实返回的结果是1。再看下面代码:

alert(2||1);

我们知道,前面2是true,后面1也是true,那返回结果又是什么呢?测试结果是2,继续看:

alert('a'||1);

同样,前面'a'是true,后面1也是true;测试结果是'a',下面

alert(''||1);

由上,我们知道前面''是false,后面1是true,而返回结果是1。再看下面

alert('a'||0);

前面'a'是true,而后面0是false,返回结果是'a',继续下面

alert('a'||'b');

前面'a'是true,后面'b'是false,返回结果是'a',我们继续下面

alert(''||0);

前面''是false,后面0同样是false,返回结果是0

alert(0||'');

前面0是false,后面''是false,返回结果是''

这就意味

1、只要“||”前面为false,不管“||”后面是true还是false,都返回“||”后面的值。

2、只要“||”前面为true,不管“||”后面是true还是false,都返回“||”前面的值。

----------------------------------------------------------------------------------------------------------

二、下面说说&&(逻辑与),从字面上来说,只有前后都是true的时候才返回true,否则返回false。

alert(true&&false);    // false
alert(true&&true); // true
alert(false&&false); // false
alert(false&&true); // false

然后,根据上面经验,我们看看“&&”号前后,不单单是布尔类型的情况。

alert(''&&1);

结是返回'',“&&”前面''是false,后面是1是true。

alert(''&&0);

结是返回'',“&&”前面''是false,后面是0也是false。

alert('a'&&1);

结是返回1,“&&”前面''a是true,后面是1也是true。

alert('a'&&0);

结是返回0,“&&”前面''a是true,后面是0是false。

alert('a'&&'');

结是返回'',“&&”前面''a是true,后面是''是false。

alert(0&&'a');

结是返回0,“&&”前面''0是false,后面是'a'是true。

alert(0&&'');

结是返回0,“&&”前面''0是false,后面是''也是false。

这意味着(大家牢记,这是结论,不用记上边的那些输出结果)

1、只要“||”前面为false,无论“||”后面是true还是false,结果都返回“||”后面的值。

2、只要“||”前面为true,无论“||”后面是true还是false,结果都返回“||”前面的值。

3、只要“&&”前面是false,无论“&&”后面是true还是false,结果都将返“&&”前面的值;

4、只要“&&”前面是true,无论“&&”后面是true还是false,结果都将返“&&”后面的值;
由上两个测试可知,逻辑运算符,“||”和“&&”都是遵行短路原则,只要确定符号前面的真假,既可确定返回值。

需要说明的是“&&”的优先级是高于“||”的,下面测试:

alert(1||'a'&&2);

返回结果是1。

根据反证原理,我们假设“||”的优先级不低于“&&”(这里只所以用“不低于”,是为了同时证明等级相同的情况)。

根据上面我们得出的结论(1),(1||'a')将返回前面的值1,(1&&2)根据结论(4)应该返回后面的值2。这显然不对,由此可知“&&”的优先级是高于“||”的。

最新文章

  1. 如何一步一步用DDD设计一个电商网站(三)—— 初涉核心域
  2. 相机位姿估计1_1:OpenCV:solvePnP二次封装与性能测试
  3. IT公司笔试题(一)
  4. map与vector---Email Aliases
  5. PHPNG (next generation)
  6. 折半查找&clock函数
  7. linux系统灵活运用灯[android课程3]
  8. 新手站长选择WordPress程序建站需要注意的8个问题
  9. AOJ2249最短路+最小费用
  10. PHP流程管理,堪比小小程序
  11. (java web后端方向)如何让你的简历为你争取到更多的面试机会,内容来自java web轻量级开发面试教程
  12. postman Could not get any response。
  13. Maven中聚合与集成的区别
  14. boke练习: @PreAuthorize authentication.name.equals的数据绑定与验证
  15. Thrift 简单实现C#通讯服务程序 (跨语言 MicroServices)
  16. Windows平台JDK安装
  17. Date类型之组件方法
  18. 「Django」rest_framework学习系列-节流控制
  19. [Luogu 1351] NOIP2014 联合权值
  20. strcpy、sprintf、memcpy的区别

热门文章

  1. JuJu团队11月26号工作汇报
  2. B - Stacks of Flapjacks UVA - 120
  3. UVA - 211 The Domino Effect(多米诺效应)(dfs回溯)
  4. python 小数相加报错 invalid literal for int() with base 10
  5. bzoj 1369: [Baltic2003]Gem
  6. spring源码 继承AttributeAccessor的BeanDefinition接口
  7. 面向对象-main函数
  8. 2016蓝桥杯省赛C/C++A组第六题 寒假作业
  9. PL/SQL表结构/数据的导出
  10. 51nod 1430:奇偶游戏 博弈