一 &&
首先说下逻辑与&&,说起来惭愧,用了好多年逻辑与只是知道条件表达式中使用它,无非是将两个true或者false的条件做下判断而已。
第一层关系,最简单的true和false的判断使用
例如
var isActive = true;
var isManager = true;
if(isActive && isManager) {
console.log('user is Manager');
}
第二种关系,判断两个条件的真假值,这里的真值并不仅仅指true,类似的数字1,2,3,非空对象,非空字符串等都属于真值;同理假值也并非只是false,类似数字0,空对象,未定义的变量等都是空值
例如
var obj = {x:0};
var name = "tom";
if(obj && name) {
console.log('name is ' + name);
}
例子中obj虽然不是true,但在这里会自动判断不是空对象就算是真值,同理name变量不是非空字符串也算是真值
第三层关系,需要深究一下,逻辑与的计算逻辑,两个条件表达式,按照从左到右的顺序,首先计算左边的表达式,如果为假值,那么放弃计算右侧的表达式;如果左边的表达式为真值,则继续计算右侧的表达式;按照这个逻辑,出现了稍微有些迷惑的写法
var min = 0;
var max = 100;
var value = 40;
if(max > value) open(); // 只有max大于value时,执行函数open
(max > value) && open(); // 同上,如果左侧表达式max大于value为真值,那么执行open函数,否则不执行
var ret = max && value; // 最后ret值为40
var ret = min && value; // 最后ret值为0
逻辑与的返回值很有意思,它会返回最后一个条件为真的值,max&&value,因为max为真值,然后计算value值也为真值,那就返回value的值;
第二个表达式,min为0是假值,那么就放弃计算value的值,直接返回min的值0
在很多代码里会看到上述写法,不管是写代码的人炫技也好,还是真的有先进性也罢,我们看到一定要知道这句话是要表达什么意思。
二 ||
逻辑非的话同逻辑与基本差不多,不同也就在于只要满足一个条件就可以了,左侧表达式如果为真值,那么就会放弃计算右侧表达式
三 赋值表达式=
赋值表达式其实很简单,就是把右侧表达式的值赋给左侧的变量或者对象
这里有个非常有意思的点在于,赋值表达式的返回值为左侧表达式的内容,也就是说,最后返回值=右侧变量获取的内容=左侧表达式的内容
var value = (max = 200);
上面的例子中,max值为200,而value同样为200