作家
登录

Javascript 中的 && 和 || 使用小结

作者: 来源:www.28hudong.com 2013-03-30 01:38:56 阅读 我要评论

普通情况下的 && 和 || 比较简单,这里不进行讨论。 准备两个对象用于下面的讨论。 复制代码 代码如下: var alice = { name: "alice", toString: function () { return this.name; } } var smith = { name: "smith", toString: function () { return this.name; } } 在 javascript 中,对于 && 不仅仅可以用于 boolean 类型,也不仅仅返回 Boolean 类型的结果。 l 如果第一个操作数是 Boolean 类型,而且值为 false ,那么直接返回 false。 l 如果第一个操作数是 Boolean 类型,而且值为 true,另外一个操作数是 object 类型,那么将返回这个对象。 l 如果两个操作数都是 object 类型,那么,返回第二个对象。 l 如果任何一个操作数是 null,那么,返回 null。 l 如果任何一个操作数是 NaN,那么返回 NaN。 l 如果任何一个操作数是 undefinded,那么返回 undefined。 alert(false && alice); // false alert(true && alice); // alice alert(alice && smith); // smith alert(smith && alice); // alice alert(null && alice); // null alert(NaN && alice); // NaN alert(undefined && alice); // undefined alert(alice && undefined); // undefined 对于 || 来说,同样也不仅仅用于 Boolean 类型,也不仅仅返回 Boolean 类型的结果。 事实上,null、undefined、NaN 都将被看作 false。而对象被当作 true。 l 如果第一个操作数是 boolean 类型,而且值为 true, 那么,直接返回 true。 l 如果第一个操作数是 Boolean 类型,而且值为 false ,第二个操作数为 object,那么返回 object 对象。 l 如果两个操作数都是 object 类型,那么返回第一个对象。 l 如果两个操作数都是 null,那么,返回 null。 l 如果两个操作数都是 NaN,那么返回 NaN。 l 如果两个操作数都是 undefined,那么,返回 undefined。 alert(false || alice); // alice alert(true || alice); // true alert(alice || smith); // alice alert(smith || alice); // smith alert(null || alice); // alice alert(alice || null); // alice alert(null || null); // null alert(NaN || alice); // alice alert(alice || NaN); // alice alert(NaN || NaN); // NaN alert(undefined || alice); // alice alert(alice || undefined); // alice alert(undefined || undefined); // undefined 不用搞得这么复杂 推荐大家看这部分的说明a && b : 将a, b转换为Boolean类型, 再执行逻辑与, true返回b, false返回a a || b : 将a, b转换为Boolean类型, 再执行逻辑或, true返回a, false返回b 转换规则: 对象为true 非零数字为true 非空字符串为true 其他为false 相关文章可以参考下面几篇,综合一下js 与或运算符 || && 妙用js利用与或运算符优先级实现if else条件判断表达式 javascript &&和||运算法的另类使用技巧

  推荐阅读

  JS判断是否为数字,是否为整数,是否为浮点数的代码

正则表达式方法 复制代码 代码如下: function checkRate(input) { var re = /^[0-9]+.?[0-9]*$/; //判断字符串是否为数字 //判断正整数 /^[1-9]+[0-9]*]*$/ if (!re.test(input.rate.value)) { alert("请输入数字(>>>详细阅读


本文标题:Javascript 中的 && 和 || 使用小结

地址:http://www.17bianji.com/kaifa2/JS/26543.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)