当前位置: 首页 > 图文教程 > 网络编程 > Javascript > javascript &&和||运算法的另类使用技巧

Javascript
添加到收藏夹代码(兼容几乎所有的浏览器)
innerHTML在Mozilla Firefox和Opera下执行的一个特例情况。
尽可能写"友好"的"Javascript"代码
在修改准备发的批量美化select+可修改select时,在非IE下发现了几个问题
添加一个以前写的table的spliter给大家
鼠标滚轮编程
googlemap 之 javascript实现方法
Javascript - 全面理解 caller,callee,call,apply
简单的仿Flash文字动画(兼容Mozilla)
客户端脚本中常常出现的一些问题和调试技巧
Prototype使用指南之hash.js
做网页的一些技巧(续)
JavaScript中“+=”的应用
Javascript的IE和Firefox兼容性汇编(zz)
js滚动条多种样式,推荐
微调数字
Div上下居中
初探jquery:表单应用范例
[原创]保存的js无法执行的解决办法
用javascript实现“闪动”标题栏

Javascript 中的 javascript &&和||运算法的另类使用技巧


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2010-01-10   浏览: 173 ::
收藏到网摘: n/a

一直以为 && 和 || 这两个伟大的运算法只能在判断表达式使用,也就是常在if语句使用,原来错了,它还可以运用在简化选择性执行语句的操作,有点拗口,简单点也就是:操作执行某条语句,不执行某条语句。 &&和||在JQuery源代码内尤为使用广泛,由于本人没有系统的学习js,所以只能粗略的自我理解出来,希望大家指点下。
粗略理解如下:
a() && b() :如果执行a()后返回true,则执行b()并返回b的值;如果执行a()后返回false,则整个表达式返回a()的值,b()不执行;
a() || b() :如果执行a()后返回true,则整个表达式返回a()的值,b()不执行;如果执行a()后返回false,则执行b()并返回b()的值;
&& 优先级高于 ||
如下:
  
代码
复制代码 代码如下:

alert((1 && 3 || 0) && 4); //结果4 ①
alert(1 && 3 || 0 && 4); //结果3 ②
alert(0 && 3 || 1 && 4); //结果4 ③

分析:
语句①:1&&3 返回3 => 3 || 0 返回 3 => 3&&4 返回 4
语句②:先执行1&&3 返回3,在执行0&&4返回0,最后执行结果比较 3||0 返回 3
语句③:先执行0&&3 返回0,在执行1&&4返回4,最后执行结果比较 0||4 返回 4
注:非0的整数都为true,undefined、null和空字符串"" 为false。