js中的||与&&用法

时间:2023-01-30 14:40:39

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,返回结果是0

?alert(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