1、||(逻辑或)
只有前后都是false的时候才返回false,否则返回true。
alert(2||1);
//2
前面2是true,后面1也是true,结果是2,alert(
'a'
||1);
//'a'
前面'a'是true,后面1也是true;测试结果是'a',alert(
''
||1);
//1
前面‘ ’ 是false,后面1是true,而返回结果是1。alert(
'a'
||0);
//'a'
前面'a'是true,而后面0是false,返回结果是'a',alert(
''
||0);
//0
前面‘ ’是false,后面0同样是false,返回结果是0alert(0||
''
);
//''
前面0是false,后面”是false,返回结果是‘ ’结论:
var
c=a()||b();
a() || b() :如果执行a()后返回true,则整个表达式返回a()的值,b()不执行;如果执行a()后返回false,则执行b()并返回b()的值;
只要“||”前面为false,不管“||”后面是true还是false,都返回“||”后面的值。
只要“||”前面为true,不管“||”后面是true还是false,都返回“||”前面的值。
2.&&(逻辑与)
只有前后都是true的时候才返回true,否则返回false。
alert(
''
&&1);
//''
结是返回‘ ’ &&前面”是false,后面是1是true。alert(
''
&&0);
//''
结是返回‘ ’ &&前面是false,后面是0也是false。alert(
'a'
&&1);
//1
结是返回1, &&前面a是true,后面是1也是true。alert(
'a'
&&0);
//0
结是返回0, &&前面‘a’是true,后面是0是false。alert(
'a'
&&
''
);
//''
结是返回” “ &&前面'a'是true,后面是' '是false。alert(0&&
'a'
);
//0
结是返回0, &&前面0是false,后面是'a'是true。alert(0&&
''
);
//0
结是返回0, &&前面0是false,后面是' '也是false。var
c=a()&&b();
a() && b() :如果执行a()后返回true,则执行b()并返回b的值;如果执行a()后返回false,则整个表达式返回a()的值,b()不执行;
只要“&&”前面是false,无论“&&”后面是true还是false,结果都将返“&&”前面的值;
只要“&&”前面是true,无论“&&”后面是true还是false,结果都将返“&&”后面的值;
在js逻辑运算中,0、" "、null、false、undefined、NaN都会判为false,其他都为true
&& 优先级高于 ||
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
二、
every()与some()方法都是JS中数组的迭代方法。
- every()是对数组中每一项运行给定函数,如果该函数对每一项返回true,则返回true。
- some()是对数组中每一项运行给定函数,如果该函数对任一项返回true,则返回true。
-
var arr = [ 1, 2, 3, 4, 5, 6 ]; console.log( arr.some( function( item, index, array ){ return item > 3; })); //结果为true console.log( arr.every( function( item, index, array ){ return item > 3; })); //结果为false
some一直在找符合条件的值,一旦找到,则不会继续迭代下去。
every从迭代开始,一旦有一个不符合条件,则不会继续迭代下去。