Javascript 中的 && 和 || 使用小结_javascript技巧

企鹅博客
企鹅博客
企鹅博客
29287
文章
0
评论
2020年9月15日03:09:18 评论 7 views 1541字阅读5分8秒

普通情况下的 && 和 || 比较简单,这里不进行讨论。

准备两个对象用于下面的讨论。

复制代码 代码如下:

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 &&和||运算法的另类使用技巧

继续阅读
weinxin
欢迎加入中国站长博客之家
本站的所有资源都会上传分享到博客之家,希望大家互相学习交流进步。
JavaScript实现经典排序算法之插入排序 js教程

JavaScript实现经典排序算法之插入排序

插入排序的代码实现虽然没有冒泡排序和选择排序那么简单粗暴,但它的原理应该是最容易理解的了,因为只要打过扑克牌的人都应该能够秒懂。像排序一手扑克牌,开始时,我们的左手为空并且桌子上的牌面向下。然后,我们...
JavaScript进阶教程(第四课第一部分)_基础知识 js教程

JavaScript进阶教程(第四课第一部分)_基础知识

在以前的课程中,我们学习了对文本和字符串的各种操作,今天我们专注于两种不同的数据类型:图象和对象。学完这一课,你将知道如何: 使用JavaScript来加速图象交换。 创建你自己的对象来使脚本易于理解...
匿名

发表评论

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: